AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

C-Header-Dateien einbinden

Ein Thema von Elko · begonnen am 17. Sep 2008 · letzter Beitrag vom 18. Sep 2008
Antwort Antwort
Elko

Registriert seit: 2. Feb 2008
52 Beiträge
 
Delphi 7 Personal
 
#1

C-Header-Dateien einbinden

  Alt 17. Sep 2008, 23:39
Hallo Leute!
Ich habe ein (für mich) irgendwie unlösbares Problem: Eigentlich will ich ein funktionierendes C-Programm, in dem einige Funktionen stehen, drastisch "kürzen", indem ich die Funktionen in eine andere C-Datei auslagere und dann in das Hauptproramm einbinde. Jedoch klappt das bei mir irgenwie nicht: Ich habe das nach folgendem Schema gemacht:

Code:
// Main.c

#include <REGAN21.H> /* Register des AN21xx   */
#include <EZREGS.H> /* Externe Register des AN21xx */
#include "onewireHEAD.h"
...
Code:
// onewireHEAD.h

#ifndef onewire_H
#define onewire_H

extern xdata unsigned char scratchpad[9] _at_ 0x0122; // 0x0122 bis 0x012A
extern xdata unsigned char temperature[2] _at_ 0x012B; // 0x012B und 0x012C
...
extern unsigned char CalcCRC(unsigned char bytes[], unsigned char groesse);
extern void ReadTemp(unsigned char RomCode[8]);
#endif
Code:
// onewire.c

#include <REGAN21.H> /* Register des AN21xx   */
#include <EZREGS.H> /* Externe Register des AN21xx */
#include "onewireHEAD.h"


int myfunc(void){
return 0xAA;
}


unsigned char CalcCRC(unsigned char bytes[], unsigned char groesse){
...
    return crc;
}

void ReadTemp(unsigned char RomCode[8]){
...
}
Soweit so gut, aber jetzt kommt beim Linken bei allen Variablen, die in den Include-Dateien <REGAN21.H> und <EZREGS.H> enthalten sind, die Fehlermeldung "MULTIPLE PUBLIC DEFINITIONS"
Das Problem sehe ich darin, dass ich die darin enthaltenen Variablen sowohl in main.c, als auch in onewire.c brauche (sonst kommt die Meldung "undefined identifier"). Hat dafür jemand eine Lösung? :confused:

Damit es keine Missverständnisse gibt, hier hab ich diese Frage auch gepostet (es hat aber leider noch keiner geantwortet...).

Viele Grüße,
Stefan
Keyboard not found. Press any key to continue.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: C-Header-Dateien einbinden

  Alt 17. Sep 2008, 23:48
Du hast sie ja auch zweimal eingebunden. Einaml in der main.c und einmal in der onewire.c.
Michael
  Mit Zitat antworten Zitat
Elko

Registriert seit: 2. Feb 2008
52 Beiträge
 
Delphi 7 Personal
 
#3

Re: C-Header-Dateien einbinden

  Alt 17. Sep 2008, 23:52
Schon klar, aber wie gesagt: Wenn ich die Direktiven
Code:
#include <REGAN21.H>
#include <EZREGS.H>
wegnehme kommt die Meldung "... undefined identifier". Also klappts so auch nicht
Keyboard not found. Press any key to continue.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#4

Re: C-Header-Dateien einbinden

  Alt 18. Sep 2008, 00:16
Wo nimmst du sie "weg"? Du musst sie dort einbinden, wo sie gebraucht werden. entweder in der Main.c oder in der onewire.c.
Michael
  Mit Zitat antworten Zitat
Elko

Registriert seit: 2. Feb 2008
52 Beiträge
 
Delphi 7 Personal
 
#5

Re: C-Header-Dateien einbinden

  Alt 18. Sep 2008, 00:25
ICh hab sie ein mal in der Datei "onewire.c" weggenommen und das andere mal in der Datei "main.c". Ich habe nämlich gedacht, wenn man in "main.c" die Datei "onewire.c" einbindet, die wiederum die beiden anderen Files included, reicht das. Aber offensichtlich reicht das nicht. Denn sonst würde ja nicht die Fehlermeldung "undefined identifier" kommen...
Und wenn ich die beiden Files
Code:
#include <REGAN21.H>
#include <EZREGS.H>
in die Datei "onewire.head.h" einbinde und dafür in den beiden anderen c-Dateien nicht, kommt die Meldung "redefinition"

Naja, das Problem ist, dass sie in beiden Dateien gebraucht werden. Wie soll ich das dann machen?
Keyboard not found. Press any key to continue.
  Mit Zitat antworten Zitat
Roachford
(Gast)

n/a Beiträge
 
#6

Re: C-Header-Dateien einbinden

  Alt 18. Sep 2008, 01:37
Du darfst in den beiden Register-Headern keine public Variablen vereinbaren. Wenn, dann als extern deklarieren und dann in dem entsprechenden .c diese Variable deklarieren.

Ein Header kann Prototypen, Struktur- und Typdefinitionen haben, aber keine globalen Variablen. Diese müssen in ein .c file und können vom Header per extern referenziert werden.
  Mit Zitat antworten Zitat
Elko

Registriert seit: 2. Feb 2008
52 Beiträge
 
Delphi 7 Personal
 
#7

Re: C-Header-Dateien einbinden

  Alt 18. Sep 2008, 14:08
Hier meine Header Datei (da scheint der Fehler nicht zu liegen):
Code:
#ifndef onewire_H
#define onewire_H

//#include <REGAN21.H>         /* Register des AN21xx   */
//#include <EZREGS.H>            /* Externe Register des AN21xx */

extern xdata unsigned char scratchcrc _at_ 0x0119;
extern xdata unsigned char RomCode[8] _at_ 0x011A; // 0x011A bis 0x0121
extern xdata unsigned char scratchpad[9] _at_ 0x0122; // 0x0122 bis 0x012A
extern xdata unsigned char temperature[2] _at_ 0x012B; // 0x012B und 0x012C

extern unsigned char CalcCRC(unsigned char bytes[], unsigned char groesse);
extern void ReadTemp(unsigned char RomCode[8]);
extern void ConvertTemp(void);
extern void ReadScratchpad(void);
extern void MatchRom(unsigned char RomCode[8]);
extern void ReadRom(void);
extern unsigned char SendByte(unsigned char byte);
extern unsigned char ReadByte(void);
extern unsigned char SendBit(unsigned char Bit);
extern unsigned char ReadBit();
extern unsigned char Reset(void);

extern int myfunc(void);
#endif
...und hier die beiden anderen Header-Dateien, die ich zwar nicht geschrieben habe, aber die meine beiden c-Source-Files brauchen:
1. REGAN21.H:
Code:
/*--------------------------------------------------------------------------
REG52.H

Header file for the Cypress AN21XX microcontroller family.
Copyright (c) 1988-2000 Keil Elektronik GmbH and Keil Software, Inc.
All rights reserved.
--------------------------------------------------------------------------*/

/*  BYTE Registers */
sfr P0    = 0x80;
sfr P1    = 0x90;
sfr P2    = 0xA0;
sfr P3    = 0xB0;
sfr PSW  = 0xD0;
sfr ACC  = 0xE0;
sfr B    = 0xF0;
sfr SP   = 0x81;
sfr DPL  = 0x82;
sfr DPH  = 0x83;
sfr PCON = 0x87;
sfr TCON = 0x88;
sfr TMOD = 0x89;
sfr TL0   = 0x8A;
sfr TL1   = 0x8B;
sfr TH0   = 0x8C;
sfr TH1   = 0x8D;
sfr IE   = 0xA8;
sfr IP   = 0xB8;
sfr SCON = 0x98;
sfr SBUF = 0x99;

/*  8052 Extensions */
sfr T2CON = 0xC8;
sfr RCAP2L = 0xCA;
sfr RCAP2H = 0xCB;
sfr TL2    = 0xCC;
sfr TH2    = 0xCD;


/*  BIT Registers */
/*  PSW */
sbit CY   = PSW^7;
sbit AC   = PSW^6;
sbit F0    = PSW^5;
sbit RS1   = PSW^4;
sbit RS0   = PSW^3;
sbit OV   = PSW^2;
sbit P    = PSW^0; //8052 only

/*  TCON */
sbit TF1   = TCON^7;
sbit TR1   = TCON^6;
sbit TF0   = TCON^5;
sbit TR0   = TCON^4;
sbit IE1   = TCON^3;
sbit IT1   = TCON^2;
sbit IE0   = TCON^1;
sbit IT0   = TCON^0;

/*  IE */
sbit EA   = IE^7;
sbit ET2   = IE^5; //8052 only
sbit ES   = IE^4;
sbit ET1   = IE^3;
sbit EX1   = IE^2;
sbit ET0   = IE^1;
sbit EX0   = IE^0;

/*  IP */
sbit PT2   = IP^5;
sbit PS   = IP^4;
sbit PT1   = IP^3;
sbit PX1   = IP^2;
sbit PT0   = IP^1;
sbit PX0   = IP^0;

/*  P3  */
sbit RD   = P3^7;
sbit WR   = P3^6;
sbit T1    = P3^5;
sbit T0    = P3^4;
sbit INT1  = P3^3;
sbit INT0  = P3^2;
sbit TXD  = P3^1;
sbit RXD  = P3^0;

/*  SCON */
sbit SM0   = SCON^7;
sbit SM1   = SCON^6;
sbit SM2   = SCON^5;
sbit REN  = SCON^4;
sbit TB8   = SCON^3;
sbit RB8   = SCON^2;
sbit TI   = SCON^1;
sbit RI   = SCON^0;

/*  P1  */
sbit T2EX = P1^1; // 8052 only
sbit T2    = P1^0; // 8052 only
             
/*  T2CON */
sbit TF2    = T2CON^7;
sbit EXF2   = T2CON^6;
sbit RCLK  = T2CON^5;
sbit TCLK  = T2CON^4;
sbit EXEN2  = T2CON^3;
sbit TR2    = T2CON^2;
sbit C_T2   = T2CON^1;
sbit CP_RL2 = T2CON^0;


2. EZRegs.h:
Code:
//-----------------------------------------------------------------------------
//   File:      ezregs.h
//   Contents:   EZ-USB register declarations and bit mask definitions.
//
//   Copyright (c) 1997 AnchorChips, Inc. All rights reserved
//-----------------------------------------------------------------------------
#ifndef EZREGS_H   /* Header Sentry */
#define EZREGS_H

/*-----------------------------------------------------------------------------
   Global Variables
-----------------------------------------------------------------------------*/
// The Ez-USB registers are defined here. There used to be 3 files containing
// this information: ezregs.h (external refs), ezregs.c (bound reg names to an
// explicit address in ezusb.lib), and ezregs.inc (included in assembly files).
// We now use ezregs.h for register address allocation instead of ezregs.c by
// using "#define ALLOCATE_EXTERN". The file ezregs.c now just includes ezregs.h.
// When using "#define ALLOCATE_EXTERN", you get:
// xdata volatile BYTE OUT7BUF[64]   _at_   0x7B40;
// Such lines used to be in ezregs.c, but now are created from ezregs.h by using
// the preprocessor. The definitions in ezregs.c were redundant.
// Incidently, these lines will not generate any space in the resulting hex
// file; they just bind the symbols to the addresses for compilation.
// Since the file ezregs.c is still used in the library build, you normally
// just need to use #include "ezregs.h" in your files (i.e. fw.c).
// If you want to generate your own (non-frameworks based) C example, then you
// just need to put "#define ALLOCATE_EXTERN" in your main program file;
// i.e. fw.c or a stand-alone C source file. Any time you link with ezusb.lib,
// it will not be necessary to "#define ALLOCATE_EXTERN".
// Without "#define ALLOCATE_EXTERN", you just get the external reference:
// extern xdata volatile BYTE OUT7BUF[64]   ;//   0x7B40;
// This uses the concatenation operator "##" to insert a comment "//"
// to cut off the end of the line, "_at_   0x7B40;", which is not wanted.
// If you modify the register definitions below, please regenerate the file
// "ezregs.inc" which uses the same basic information, but which could not be
// derived automatically from this one source file using the preprocessor.

#ifdef ALLOCATE_EXTERN
#define EXTERN
#define _AT_ _at_
#else
#define EXTERN extern
#define _AT_ ;/ ## /
#endif

/* Register Assignments 3/18/99 TPM */
EXTERN xdata volatile BYTE OUT7BUF[64]   _AT_   0x7B40;
EXTERN xdata volatile BYTE IN7BUF[64]   _AT_   0x7B80;
EXTERN xdata volatile BYTE OUT6BUF[64]   _AT_   0x7BC0;
EXTERN xdata volatile BYTE IN6BUF[64]   _AT_   0x7C00;
EXTERN xdata volatile BYTE OUT5BUF[64]   _AT_   0x7C40;
EXTERN xdata volatile BYTE IN5BUF[64]   _AT_   0x7C80;
EXTERN xdata volatile BYTE OUT4BUF[64]   _AT_   0x7CC0;
EXTERN xdata volatile BYTE IN4BUF[64]   _AT_   0x7D00;
EXTERN xdata volatile BYTE OUT3BUF[64]   _AT_   0x7D40;
EXTERN xdata volatile BYTE IN3BUF[64]   _AT_   0x7D80;
EXTERN xdata volatile BYTE OUT2BUF[64]   _AT_   0x7DC0;
EXTERN xdata volatile BYTE IN2BUF[64]   _AT_   0x7E00;
EXTERN xdata volatile BYTE OUT1BUF[64]   _AT_   0x7E40;
EXTERN xdata volatile BYTE IN1BUF[64]   _AT_   0x7E80;
EXTERN xdata volatile BYTE OUT0BUF[64]   _AT_   0x7EC0;
EXTERN xdata volatile BYTE IN0BUF[64]   _AT_   0x7F00;
EXTERN xdata volatile BYTE OUT8DATA   _AT_   0x7F60;
EXTERN xdata volatile BYTE OUT9DATA   _AT_   0x7F61;
EXTERN xdata volatile BYTE OUT10DATA   _AT_   0x7F62;
EXTERN xdata volatile BYTE OUT11DATA   _AT_   0x7F63;
EXTERN xdata volatile BYTE OUT12DATA   _AT_   0x7F64;
EXTERN xdata volatile BYTE OUT13DATA   _AT_   0x7F65;
EXTERN xdata volatile BYTE OUT14DATA   _AT_   0x7F66;
EXTERN xdata volatile BYTE OUT15DATA   _AT_   0x7F67;
EXTERN xdata volatile BYTE IN8DATA   _AT_   0x7F68;
EXTERN xdata volatile BYTE IN9DATA   _AT_   0x7F69;
EXTERN xdata volatile BYTE IN10DATA   _AT_   0x7F6A;
EXTERN xdata volatile BYTE IN11DATA   _AT_   0x7F6B;
EXTERN xdata volatile BYTE IN12DATA   _AT_   0x7F6C;
EXTERN xdata volatile BYTE IN13DATA   _AT_   0x7F6D;
EXTERN xdata volatile BYTE IN14DATA   _AT_   0x7F6E;
EXTERN xdata volatile BYTE IN15DATA   _AT_   0x7F6F;
EXTERN xdata volatile BYTE OUT8BCH   _AT_   0x7F70;
EXTERN xdata volatile BYTE OUT8BCL   _AT_   0x7F71;
EXTERN xdata volatile BYTE OUT9BCH   _AT_   0x7F72;
EXTERN xdata volatile BYTE OUT9BCL   _AT_   0x7F73;
EXTERN xdata volatile BYTE OUT10BCH   _AT_   0x7F74;
EXTERN xdata volatile BYTE OUT10BCL   _AT_   0x7F75;
EXTERN xdata volatile BYTE OUT11BCH   _AT_   0x7F76;
EXTERN xdata volatile BYTE OUT11BCL   _AT_   0x7F77;
EXTERN xdata volatile BYTE OUT12BCH   _AT_   0x7F78;
EXTERN xdata volatile BYTE OUT12BCL   _AT_   0x7F79;
EXTERN xdata volatile BYTE OUT13BCH   _AT_   0x7F7A;
EXTERN xdata volatile BYTE OUT13BCL   _AT_   0x7F7B;
EXTERN xdata volatile BYTE OUT14BCH   _AT_   0x7F7C;
EXTERN xdata volatile BYTE OUT14BCL   _AT_   0x7F7D;
EXTERN xdata volatile BYTE OUT15BCH   _AT_   0x7F7E;
EXTERN xdata volatile BYTE OUT15BCL   _AT_   0x7F7F;
EXTERN xdata volatile BYTE CPUCS   _AT_   0x7F92;
EXTERN xdata volatile BYTE PORTACFG   _AT_   0x7F93;
EXTERN xdata volatile BYTE PORTBCFG   _AT_   0x7F94;
EXTERN xdata volatile BYTE PORTCCFG   _AT_   0x7F95;
EXTERN xdata volatile BYTE OUTA      _AT_   0x7F96;
EXTERN xdata volatile BYTE OUTB      _AT_   0x7F97;
EXTERN xdata volatile BYTE OUTC      _AT_   0x7F98;
EXTERN xdata volatile BYTE PINSA   _AT_   0x7F99;
EXTERN xdata volatile BYTE PINSB   _AT_   0x7F9A;
EXTERN xdata volatile BYTE PINSC   _AT_   0x7F9B;
EXTERN xdata volatile BYTE OEA      _AT_   0x7F9C;
EXTERN xdata volatile BYTE OEB      _AT_   0x7F9D;
EXTERN xdata volatile BYTE OEC      _AT_   0x7F9E;
EXTERN xdata volatile BYTE UART230   _AT_   0x7F9F;
EXTERN xdata volatile BYTE ISOERR   _AT_   0x7FA0;
EXTERN xdata volatile BYTE ISOCTL   _AT_   0x7FA1;
EXTERN xdata volatile BYTE ZBCOUT   _AT_   0x7FA2;
EXTERN xdata volatile BYTE ZBCIN   _AT_   0x7FA3;
EXTERN xdata volatile BYTE I2CS      _AT_   0x7FA5;
EXTERN xdata volatile BYTE I2DAT   _AT_   0x7FA6;
EXTERN xdata volatile BYTE IVEC      _AT_   0x7FA8;
EXTERN xdata volatile BYTE IN07IRQ   _AT_   0x7FA9;
EXTERN xdata volatile BYTE OUT07IRQ   _AT_   0x7FAA;
EXTERN xdata volatile BYTE USBIRQ   _AT_   0x7FAB;
EXTERN xdata volatile BYTE IN07IEN   _AT_   0x7FAC;
EXTERN xdata volatile BYTE OUT07IEN   _AT_   0x7FAD;
EXTERN xdata volatile BYTE USBIEN   _AT_   0x7FAE;
EXTERN xdata volatile BYTE USBBAV   _AT_   0x7FAF;
EXTERN xdata volatile WORD BPADDR   _AT_   0x7FB2;
//volatile EXTERN xdata BYTE BPADDRL   _AT_   0x7FB3;
EXTERN xdata volatile EPIOC EPIO[16]   _AT_   0x7FB4;
EXTERN xdata volatile BYTE SUDPTRH   _AT_   0x7FD4;
EXTERN xdata volatile BYTE SUDPTRL   _AT_   0x7FD5;
EXTERN xdata volatile BYTE USBCS   _AT_   0x7FD6;
EXTERN xdata volatile BYTE TOGCTL   _AT_   0x7FD7;
EXTERN xdata volatile BYTE USBFRAMEL   _AT_   0x7FD8;
EXTERN xdata volatile BYTE USBFRAMEH   _AT_   0x7FD9;
EXTERN xdata volatile BYTE FNADDR   _AT_   0x7FDB;
EXTERN xdata volatile BYTE USBPAIR   _AT_   0x7FDD;
EXTERN xdata volatile BYTE IN07VAL   _AT_   0x7FDE;
EXTERN xdata volatile BYTE OUT07VAL   _AT_   0x7FDF;
EXTERN xdata volatile BYTE INISOVAL   _AT_   0x7FE0;
EXTERN xdata volatile BYTE OUTISOVAL   _AT_   0x7FE1;
EXTERN xdata volatile BYTE FASTXFR   _AT_   0x7FE2;
EXTERN xdata volatile BYTE AUTOPTRH   _AT_   0x7FE3;
EXTERN xdata volatile BYTE AUTOPTRL   _AT_   0x7FE4;
EXTERN xdata volatile BYTE AUTODATA   _AT_   0x7FE5;
EXTERN xdata volatile BYTE SETUPDAT[8]   _AT_   0x7FE8;
EXTERN xdata volatile BYTE OUT8ADDR   _AT_   0x7FF0;
EXTERN xdata volatile BYTE OUT9ADDR   _AT_   0x7FF1;
EXTERN xdata volatile BYTE OUT10ADDR   _AT_   0x7FF2;
EXTERN xdata volatile BYTE OUT11ADDR   _AT_   0x7FF3;
EXTERN xdata volatile BYTE OUT12ADDR   _AT_   0x7FF4;
EXTERN xdata volatile BYTE OUT13ADDR   _AT_   0x7FF5;
EXTERN xdata volatile BYTE OUT14ADDR   _AT_   0x7FF6;
EXTERN xdata volatile BYTE OUT15ADDR   _AT_   0x7FF7;
EXTERN xdata volatile BYTE IN8ADDR   _AT_   0x7FF8;
EXTERN xdata volatile BYTE IN9ADDR   _AT_   0x7FF9;
EXTERN xdata volatile BYTE IN10ADDR   _AT_   0x7FFA;
EXTERN xdata volatile BYTE IN11ADDR   _AT_   0x7FFB;
EXTERN xdata volatile BYTE IN12ADDR   _AT_   0x7FFC;
EXTERN xdata volatile BYTE IN13ADDR   _AT_   0x7FFD;
EXTERN xdata volatile BYTE IN14ADDR   _AT_   0x7FFE;
EXTERN xdata volatile BYTE IN15ADDR   _AT_   0x7FFF;

#undef EXTERN
#undef _AT_

/*-----------------------------------------------------------------------------
   Special Function Registers (SFRs)
   The byte registers and bits defined in the following list are based
   on the Synopsis definition of the 8051 Special Function Registers for EZ-USB.
    If you modify the register definitions below, please regenerate the file
    "ezregs.inc" which includes the same basic information for assembly inclusion.
-----------------------------------------------------------------------------*/

sfr SP     = 0x81;
sfr DPL    = 0x82;
sfr DPH    = 0x83;
sfr DPL1    = 0x84;
sfr DPH1    = 0x85;
sfr DPS    = 0x86;
         /*  DPS */
         sbit SEL  = 0x86+0;
sfr PCON   = 0x87;   /*  PCON */
         //sbit IDLE  = 0x87+0;
         //sbit STOP  = 0x87+1;
         //sbit GF0    = 0x87+2;
         //sbit GF1    = 0x87+3;
         //sbit SMOD0  = 0x87+7;
sfr TCON   = 0x88;
         /*  TCON */
         sbit IT0    = 0x88+0;
         sbit IE0    = 0x88+1;
         sbit IT1    = 0x88+2;
         sbit IE1    = 0x88+3;
         sbit TR0    = 0x88+4;
         sbit TF0    = 0x88+5;
         sbit TR1    = 0x88+6;
         sbit TF1    = 0x88+7;
sfr TMOD   = 0x89;
         /*  TMOD */
         //sbit M00    = 0x89+0;
         //sbit M10    = 0x89+1;
         //sbit CT0    = 0x89+2;
         //sbit GATE0  = 0x89+3;
         //sbit M01    = 0x89+4;
         //sbit M11    = 0x89+5;
         //sbit CT1    = 0x89+6;
         //sbit GATE1  = 0x89+7;
sfr TL0     = 0x8A;
sfr TL1     = 0x8B;
sfr TH0     = 0x8C;
sfr TH1     = 0x8D;
sfr CKCON  = 0x8E;
         /*  CKCON */
         //sbit MD0    = 0x89+0;
         //sbit MD1    = 0x89+1;
         //sbit MD2    = 0x89+2;
         //sbit T0M   = 0x89+3;
         //sbit T1M   = 0x89+4;
         //sbit T2M   = 0x89+5;
sfr SPC_FNC = 0x8F; // Was WRS in Reg320
         /*  CKCON */
         //sbit WRS   = 0x8F+0;
sfr EXIF   = 0x91; // EXIF Bit Values differ from Reg320
         /*  EXIF */
         //sbit USBINT = 0x91+4;
         //sbit I2CINT = 0x91+5;
         //sbit IE4    = 0x91+6;
         //sbit IE5    = 0x91+7;
sfr MPAGE = 0x92;
sfr SCON0  = 0x98;
         /*  SCON0  */
         sbit RI   = 0x98+0;
         sbit TI   = 0x98+1;
         sbit RB8   = 0x98+2;
         sbit TB8   = 0x98+3;
         sbit REN  = 0x98+4;
         sbit SM2   = 0x98+5;
         sbit SM1   = 0x98+6;
         sbit SM0   = 0x98+7;
sfr SBUF0  = 0x99;
sfr IE    = 0xA8;
         /*  IE */
         sbit EX0   = 0xA8+0;
         sbit ET0   = 0xA8+1;
         sbit EX1   = 0xA8+2;
         sbit ET1   = 0xA8+3;
         sbit ES0   = 0xA8+4;
         sbit ET2   = 0xA8+5;
         sbit ES1   = 0xA8+6;
         sbit EA   = 0xA8+7;
sfr IP    = 0xB8;
         /*  IP */
         sbit PX0   = 0xB8+0;
         sbit PT0   = 0xB8+1;
         sbit PX1   = 0xB8+2;
         sbit PT1   = 0xB8+3;
         sbit PS0   = 0xB8+4;
         sbit PT2   = 0xB8+5;
         sbit PS1   = 0xB8+6;
sfr SCON1  = 0xC0;
         /*  SCON1  */
         sbit RI1   = 0xC0+0;
         sbit TI1   = 0xC0+1;
         sbit RB81  = 0xC0+2;
         sbit TB81  = 0xC0+3;
         sbit REN1  = 0xC0+4;
         sbit SM21  = 0xC0+5;
         sbit SM11  = 0xC0+6;
         sbit SM01  = 0xC0+7;
sfr SBUF1  = 0xC1;
sfr T2CON = 0xC8;
         /*  T2CON */
         sbit CP_RL2 = 0xC8+0;
         sbit C_T2  = 0xC8+1;
         sbit TR2   = 0xC8+2;
         sbit EXEN2 = 0xC8+3;
         sbit TCLK = 0xC8+4;
         sbit RCLK = 0xC8+5;
         sbit EXF2  = 0xC8+6;
         sbit TF2   = 0xC8+7;
sfr RCAP2L = 0xCA;
sfr RCAP2H = 0xCB;
sfr TL2    = 0xCC;
sfr TH2    = 0xCD;
sfr PSW   = 0xD0;
         /*  PSW */
         sbit P    = 0xD0+0;
         sbit FL   = 0xD0+1;
         sbit OV   = 0xD0+2;
         sbit RS0   = 0xD0+3;
         sbit RS1   = 0xD0+4;
         sbit F0    = 0xD0+5;
         sbit AC   = 0xD0+6;
         sbit CY   = 0xD0+7;
sfr EICON = 0xD8; // Was WDCON in DS80C320; Bit Values differ from Reg320
         /*  EICON */
         sbit INT6  = 0xD8+3;
         sbit RESI = 0xD8+4;
         sbit ERESI = 0xD8+5;
         sbit SMOD1 = 0xD8+7;
sfr ACC   = 0xE0;
sfr EIE   = 0xE8; // EIE Bit Values differ from Reg320
                        /*  EIE */
         sbit EUSB   = 0xE8+0;
         sbit EI2C   = 0xE8+1;
         sbit EIEX4   = 0xE8+2;
         sbit EIEX5   = 0xE8+3;
         sbit EIEX6   = 0xE8+4;
sfr B     = 0xF0;
sfr EIP   = 0xF8; // EIP Bit Values differ from Reg320
                        /*  EIP */
         sbit PUSB   = 0xF8+0;
         sbit PI2C   = 0xF8+1;
         sbit EIPX4   = 0xF8+2;
         sbit EIPX5   = 0xF8+3;
         sbit EIPX6   = 0xF8+4;

/*-----------------------------------------------------------------------------
   Bit Masks
-----------------------------------------------------------------------------*/

/* CPU Control & Status Register */
#define bmCHIPREV      (bmBIT7 | bmBIT6 | bmBIT5 | bmBIT4)
#define bmCLK24OE      bmBIT1
#define bm8052RES      bmBIT0
/* Port Configuration Registers */
/* Port A */
#define bmRXD1OUT      bmBIT7
#define bmRXD0OUT      bmBIT6
#define bmFRD         bmBIT5
#define bmFWR         bmBIT4
#define bmCS         bmBIT3
#define bmOE         bmBIT2
#define bmT1OUT         bmBIT1
#define bmT0OUT         bmBIT0
/* Port B */
#define bmT2OUT         bmBIT7
#define bmINT6         bmBIT6
#define bmINT5         bmBIT5
#define bmINT4         bmBIT4
#define bmTXD1         bmBIT3
#define bmRXD1         bmBIT2
#define bmT2EX         bmBIT1
#define bmT2         bmBIT0
/* Port C */
#define bmRD         bmBIT7
#define bmWR         bmBIT6
#define bmT1         bmBIT5
#define bmT0         bmBIT4
#define bmINT1         bmBIT3
#define bmINT0         bmBIT2
#define bmTXD0         bmBIT1
#define bmRXD0         bmBIT0
/* Isochronous Status & End Point Valid Registers */
#define bmEP15         bmBIT7
#define bmEP14         bmBIT6
#define bmEP13         bmBIT5
#define bmEP12         bmBIT4
#define bmEP11         bmBIT3
#define bmEP10         bmBIT2
#define bmEP9         bmBIT1
#define bmEP8         bmBIT0
/* I2C Control & Status Register */
#define bmSTART         bmBIT7
#define bmSTOP         bmBIT6
#define bmLASTRD      bmBIT5
#define bmID         (bmBIT4 | bmBIT3)
#define bmBERR         bmBIT2
#define bmACK         bmBIT1
#define bmDONE         bmBIT0
/* Interrupt Vector Register */
#define bmIV4         bmBIT6
#define bmIV3         bmBIT5
#define bmIV2         bmBIT4
#define bmIV1         bmBIT3
#define bmIV0         bmBIT2
/* End point Interrupt Request, End Point Interrupt Enable */
/* And End Point Valid Registers */
#define bmEP7         bmBIT7
#define bmEP6         bmBIT6
#define bmEP5         bmBIT5
#define bmEP4         bmBIT4
#define bmEP3         bmBIT3
#define bmEP2         bmBIT2
#define bmEP1         bmBIT1
#define bmEP0         bmBIT0
/* Global Interrupt Request & Enable Registers */
#define bmIBN       bmBIT5
#define bmURES         bmBIT4
#define bmSUSP         bmBIT3
#define bmSUTOK         bmBIT2
#define bmSOF         bmBIT1
#define bmSUDAV         bmBIT0
/* Global Control */
#define bmBREAK         bmBIT3
#define bmBPPULSE      bmBIT2
#define bmBPEN         bmBIT1
#define bmAVEN         bmBIT0
/* USB Control & Status Register */
#define bmRWAKEUP      bmBIT7
#define bmDISCON      bmBIT3
#define bmDISCOE      bmBIT2
#define bmRENUM         bmBIT1
#define bmSIGRESUME      bmBIT0
/* End Point 0 Control & Status Register */
#define bmOUT         bmBIT3
#define bmIN         bmBIT2
#define bmHS         bmBIT1
#define bmHSSTALL      bmBIT0
/* End Point Control & Status Registers */
#define bmEPSTALL      bmBIT0
#define bmEPBUSY      bmBIT1
/* Fast Transfer Register */
#define bmFISO         bmBIT7
#define bmFBLK         bmBIT6
#define bmRPOL         bmBIT5
#define bmRMOD1         bmBIT4
#define bmRMOD0         bmBIT3
#define bmWPOL         bmBIT2
#define bmWMOD1         bmBIT1
#define bmWMOD0         bmBIT0
/* Endpoint Pairing Register */
#define bmISOSEND0      bmBIT7
#define bmPR6OUT      bmBIT5
#define bmPR4OUT      bmBIT4
#define bmPR2OUT      bmBIT3
#define bmPR6IN         bmBIT2
#define bmPR4IN         bmBIT1
#define bmPR2IN         bmBIT0
/* End point control offsets */
enum
{
   IN0BUF_ID = 0,
   IN1BUF_ID,
   IN2BUF_ID,
   IN3BUF_ID,
   IN4BUF_ID,
   IN5BUF_ID,
   IN6BUF_ID,
   IN7BUF_ID,
   OUT0BUF_ID,
   OUT1BUF_ID,
   OUT2BUF_ID,
   OUT3BUF_ID,
   OUT4BUF_ID,
   OUT5BUF_ID,
   OUT6BUF_ID,
   OUT7BUF_ID
};

#define EP0CS   EPIO[0].cntrl
#define IN0BC   EPIO[0].bytes
#define IN1CS   EPIO[1].cntrl
#define IN1BC   EPIO[1].bytes
#define IN2CS   EPIO[2].cntrl
#define IN2BC   EPIO[2].bytes
#define IN3CS   EPIO[3].cntrl
#define IN3BC   EPIO[3].bytes
#define IN4CS   EPIO[4].cntrl
#define IN4BC   EPIO[4].bytes
#define IN5CS   EPIO[5].cntrl
#define IN5BC   EPIO[5].bytes
#define IN6CS   EPIO[6].cntrl
#define IN6BC   EPIO[6].bytes
#define IN7CS   EPIO[7].cntrl
#define IN7BC   EPIO[7].bytes
#define OUT0CS   EPIO[8].cntrl
#define OUT0BC   EPIO[8].bytes
#define OUT1CS   EPIO[9].cntrl
#define OUT1BC   EPIO[9].bytes
#define OUT2CS   EPIO[10].cntrl
#define OUT2BC   EPIO[10].bytes
#define OUT3CS   EPIO[11].cntrl
#define OUT3BC   EPIO[11].bytes
#define OUT4CS   EPIO[12].cntrl
#define OUT4BC   EPIO[12].bytes
#define OUT5CS   EPIO[13].cntrl
#define OUT5BC   EPIO[13].bytes
#define OUT6CS   EPIO[14].cntrl
#define OUT6BC   EPIO[14].bytes
#define OUT7CS   EPIO[15].cntrl
#define OUT7BC   EPIO[15].bytes

/*-----------------------------------------------------------------------------
   Macros
-----------------------------------------------------------------------------*/
/* Convert End point ID (d0000eee) to EPIO offset */
#define EPID(id)      (((~id & 0x80) >> 4) + (id & 0x07))


#endif   /* EZREGS_H */
So, ich hoffe, dass das weiterhilft
Noch eine Anmerkung: es kommt die Fehlermeldung "MULTIPLE PUBLIC DEFINITIONS" in Zusammenhang mit den Variablen "PINSB", etc, die in der letzten Header-Datei enthalten sind (aber die sind doch als extern deklariert?).

Viele Grüße,
Stefan
Keyboard not found. Press any key to continue.
  Mit Zitat antworten Zitat
MrKnogge

Registriert seit: 9. Jun 2003
Ort: Pforzheim
2.458 Beiträge
 
Delphi 2007 Professional
 
#8

Re: C-Header-Dateien einbinden

  Alt 18. Sep 2008, 14:28
Zitat von Elko:
Ich habe nämlich gedacht, wenn man in "main.c" die Datei "onewire.c" einbindet
C-Dateien können nicht eingebunden werden.
Christian Bootz
Einstein ist tot, Newton ist tot,
und mir ist auch schon ganz schlecht...
  Mit Zitat antworten Zitat
Elko

Registriert seit: 2. Feb 2008
52 Beiträge
 
Delphi 7 Personal
 
#9

Re: C-Header-Dateien einbinden

  Alt 18. Sep 2008, 15:09
Sry, aber ich habe auch onewire.h gemeint
Keyboard not found. Press any key to continue.
  Mit Zitat antworten Zitat
Elko

Registriert seit: 2. Feb 2008
52 Beiträge
 
Delphi 7 Personal
 
#10

Re: C-Header-Dateien einbinden

  Alt 18. Sep 2008, 17:55
Hallo!
ich bin mir nun ziemlich sicher, dass das Problem nicht an meinem Header+Sourcefile liegt, sondern an einem der von beiden c-Sourcefiles eingebundenen Headern. Hier werden anscheinend globale Variablen definiert, was meines Erachtens zu dem Compilerfehler "Multiple Public Definitions" führt. HAt jemand eine Idee, wie man die Variablen aus diesem Headerfile den beiden Sourcefiles bekannt machen kann, ohne dass der Compilerfehler kommt?
Da ich im vorigen Post glaube ich eine falsche Version des Headers genommen hab, hier nochmals die richtige:
Code:
//-----------------------------------------------------------------------------
//   File:      ezregs.h
//   Contents:   EZ-USB register declarations and bit mask definitions.
//
//   Copyright (c) 1997 AnchorChips, Inc. All rights reserved
//-----------------------------------------------------------------------------
#ifndef EZREGS_H   /* Header Sentry */
#define EZREGS_H

/*-----------------------------------------------------------------------------
   Global Variables
-----------------------------------------------------------------------------*/
// The Ez-USB registers are defined here. There used to be 3 files containing
// this information: ezregs.h (external refs), ezregs.c (bound reg names to an
// explicit address in ezusb.lib), and ezregs.inc (included in assembly files).
// We now use ezregs.h for register address allocation instead of ezregs.c by
// using "#define ALLOCATE_EXTERN". The file ezregs.c now just includes ezregs.h.
// When using "#define ALLOCATE_EXTERN", you get:
// xdata volatile BYTE OUT7BUF[64]   _at_   0x7B40;
// Such lines used to be in ezregs.c, but now are created from ezregs.h by using
// the preprocessor. The definitions in ezregs.c were redundant.
// Incidently, these lines will not generate any space in the resulting hex
// file; they just bind the symbols to the addresses for compilation.
// Since the file ezregs.c is still used in the library build, you normally
// just need to use #include "ezregs.h" in your files (i.e. fw.c).
// If you want to generate your own (non-frameworks based) C example, then you
// just need to put "#define ALLOCATE_EXTERN" in your main program file;
// i.e. fw.c or a stand-alone C source file. Any time you link with ezusb.lib,
// it will not be necessary to "#define ALLOCATE_EXTERN".
// Without "#define ALLOCATE_EXTERN", you just get the external reference:
// xdata unsigned char OUT7BUF[64]   ;//   0x7B40;
// This uses the concatenation operator "##" to insert a comment "//"
// to cut off the end of the line, "_at_   0x7B40;", which is not wanted.
// If you modify the register definitions below, please regenerate the file
// "ezregs.inc" which uses the same basic information, but which could not be
// derived automatically from this one source file using the preprocessor.


/* Register Assignments 3/18/99 TPM */
xdata unsigned char OUT7BUF[64]   _at_   0x7B40;
xdata unsigned char IN7BUF[64]   _at_   0x7B80;
xdata unsigned char OUT6BUF[64]   _at_   0x7BC0;
xdata unsigned char IN6BUF[64]   _at_   0x7C00;
xdata unsigned char OUT5BUF[64]   _at_   0x7C40;
xdata unsigned char IN5BUF[64]   _at_   0x7C80;
xdata unsigned char OUT4BUF[64]   _at_   0x7CC0;
xdata unsigned char IN4BUF[64]   _at_   0x7D00;
xdata unsigned char OUT3BUF[64]   _at_   0x7D40;
xdata unsigned char IN3BUF[64]   _at_   0x7D80;
xdata unsigned char OUT2BUF[64]   _at_   0x7DC0;
xdata unsigned char IN2BUF[64]   _at_   0x7E00;
xdata unsigned char OUT1BUF[64]   _at_   0x7E40;
xdata unsigned char IN1BUF[64]   _at_   0x7E80;
xdata unsigned char OUT0BUF[64]   _at_   0x7EC0;
xdata unsigned char IN0BUF[64]   _at_   0x7F00;
xdata unsigned char OUT8DATA   _at_   0x7F60;
xdata unsigned char OUT9DATA   _at_   0x7F61;
xdata unsigned char OUT10DATA   _at_   0x7F62;
xdata unsigned char OUT11DATA   _at_   0x7F63;
xdata unsigned char OUT12DATA   _at_   0x7F64;
xdata unsigned char OUT13DATA   _at_   0x7F65;
xdata unsigned char OUT14DATA   _at_   0x7F66;
xdata unsigned char OUT15DATA   _at_   0x7F67;
xdata unsigned char IN8DATA      _at_   0x7F68;
xdata unsigned char IN9DATA      _at_   0x7F69;
xdata unsigned char IN10DATA   _at_   0x7F6A;
xdata unsigned char IN11DATA   _at_   0x7F6B;
xdata unsigned char IN12DATA   _at_   0x7F6C;
xdata unsigned char IN13DATA   _at_   0x7F6D;
xdata unsigned char IN14DATA   _at_   0x7F6E;
xdata unsigned char IN15DATA   _at_   0x7F6F;
xdata unsigned char OUT8BCH      _at_   0x7F70;
xdata unsigned char OUT8BCL      _at_   0x7F71;
xdata unsigned char OUT9BCH      _at_   0x7F72;
xdata unsigned char OUT9BCL      _at_   0x7F73;
xdata unsigned char OUT10BCH   _at_   0x7F74;
xdata unsigned char OUT10BCL   _at_   0x7F75;
xdata unsigned char OUT11BCH   _at_   0x7F76;
xdata unsigned char OUT11BCL   _at_   0x7F77;
xdata unsigned char OUT12BCH   _at_   0x7F78;
xdata unsigned char OUT12BCL   _at_   0x7F79;
xdata unsigned char OUT13BCH   _at_   0x7F7A;
xdata unsigned char OUT13BCL   _at_   0x7F7B;
xdata unsigned char OUT14BCH   _at_   0x7F7C;
xdata unsigned char OUT14BCL   _at_   0x7F7D;
xdata unsigned char OUT15BCH   _at_   0x7F7E;
xdata unsigned char OUT15BCL   _at_   0x7F7F;
xdata unsigned char CPUCS      _at_   0x7F92;
xdata unsigned char PORTACFG   _at_   0x7F93;
xdata unsigned char PORTBCFG   _at_   0x7F94;
xdata unsigned char PORTCCFG   _at_   0x7F95;
xdata unsigned char OUTA      _at_   0x7F96;
xdata unsigned char OUTB      _at_   0x7F97;
xdata unsigned char OUTC      _at_   0x7F98;
xdata unsigned char PINSA      _at_   0x7F99;
xdata unsigned char PINSB      _at_   0x7F9A;
xdata unsigned char PINSC      _at_   0x7F9B;
xdata unsigned char OEA         _at_   0x7F9C;
xdata unsigned char OEB         _at_   0x7F9D;
xdata unsigned char OEC         _at_   0x7F9E;
xdata unsigned char UART230      _at_   0x7F9F;
xdata unsigned char ISOERR      _at_   0x7FA0;
xdata unsigned char ISOCTL      _at_   0x7FA1;
xdata unsigned char ZBCOUT      _at_   0x7FA2;
xdata unsigned char ZBCIN      _at_   0x7FA3;
xdata unsigned char I2CS      _at_   0x7FA5;
xdata unsigned char I2DAT      _at_   0x7FA6;
xdata unsigned char IVEC      _at_   0x7FA8;
xdata unsigned char IN07IRQ      _at_   0x7FA9;
xdata unsigned char OUT07IRQ   _at_   0x7FAA;
xdata unsigned char USBIRQ      _at_   0x7FAB;
xdata unsigned char IN07IEN      _at_   0x7FAC;
xdata unsigned char OUT07IEN   _at_   0x7FAD;
xdata unsigned char USBIEN      _at_   0x7FAE;
xdata unsigned char USBBAV      _at_   0x7FAF;
xdata unsigned char IBNIRQ      _at_   0x7FB0;
xdata unsigned char IBNIEN      _at_   0x7FB1;
xdata BPADDR               _at_   0x7FB2;
//volatile EXTERN xdata BYTE BPADDRL   _at_   0x7FB3;
xdata EPIO[16]               _at_   0x7FB4;
xdata unsigned char SUDPTRH      _at_   0x7FD4;
xdata unsigned char SUDPTRL      _at_   0x7FD5;
xdata unsigned char USBCS      _at_   0x7FD6;
xdata unsigned char TOGCTL      _at_   0x7FD7;
xdata unsigned char USBFRAMEL   _at_   0x7FD8;
xdata unsigned char USBFRAMEH   _at_   0x7FD9;
xdata unsigned char FNADDR      _at_   0x7FDB;
xdata unsigned char USBPAIR      _at_   0x7FDD;
xdata unsigned char IN07VAL      _at_   0x7FDE;
xdata unsigned char OUT07VAL   _at_   0x7FDF;
xdata unsigned char INISOVAL   _at_   0x7FE0;
xdata unsigned char OUTISOVAL   _at_   0x7FE1;
xdata unsigned char FASTXFR      _at_   0x7FE2;
xdata unsigned char AUTOPTRH   _at_   0x7FE3;
xdata unsigned char AUTOPTRL   _at_   0x7FE4;
xdata unsigned char AUTODATA   _at_   0x7FE5;
xdata unsigned char SETUPDAT[8]   _at_   0x7FE8;
xdata unsigned char OUT8ADDR   _at_   0x7FF0;
xdata unsigned char OUT9ADDR   _at_   0x7FF1;
xdata unsigned char OUT10ADDR   _at_   0x7FF2;
xdata unsigned char OUT11ADDR   _at_   0x7FF3;
xdata unsigned char OUT12ADDR   _at_   0x7FF4;
xdata unsigned char OUT13ADDR   _at_   0x7FF5;
xdata unsigned char OUT14ADDR   _at_   0x7FF6;
xdata unsigned char OUT15ADDR   _at_   0x7FF7;
xdata unsigned char IN8ADDR      _at_   0x7FF8;
xdata unsigned char IN9ADDR      _at_   0x7FF9;
xdata unsigned char IN10ADDR   _at_   0x7FFA;
xdata unsigned char IN11ADDR   _at_   0x7FFB;
xdata unsigned char IN12ADDR   _at_   0x7FFC;
xdata unsigned char IN13ADDR   _at_   0x7FFD;
xdata unsigned char IN14ADDR   _at_   0x7FFE;
xdata unsigned char IN15ADDR   _at_   0x7FFF;

/*-----------------------------------------------------------------------------
   Special Function Registers (SFRs)
   The byte registers and bits defined in the following list are based
   on the Synopsis definition of the 8051 Special Function Registers for EZ-USB.
    If you modify the register definitions below, please regenerate the file
    "ezregs.inc" which includes the same basic information for assembly inclusion.
-----------------------------------------------------------------------------*/

//sfr SP     = 0x81;
//sfr DPL    = 0x82;
//sfr DPH    = 0x83;
sfr DPL1    = 0x84;
sfr DPH1    = 0x85;
sfr DPS    = 0x86;
         /*  DPS */
         sbit SEL  = 0x86+0;
//sfr PCON   = 0x87;   /*  PCON */
         sbit IDLE  = 0x87+0;
         sbit STOP  = 0x87+1;
         sbit GF0    = 0x87+2;
         sbit GF1    = 0x87+3;
         sbit SMOD0  = 0x87+7;
//sfr TCON   = 0x88;
         /*  TCON */
/*         sbit IT0    = 0x88+0;
         sbit IE0    = 0x88+1;
         sbit IT1    = 0x88+2;
         sbit IE1    = 0x88+3;
         sbit TR0    = 0x88+4;
         sbit TF0    = 0x88+5;
         sbit TR1    = 0x88+6;
         sbit TF1    = 0x88+7;   */
//sfr TMOD   = 0x89;
         /*  TMOD */
         sbit M00    = 0x89+0;
         sbit M10    = 0x89+1;
         sbit CT0    = 0x89+2;
         sbit GATE0  = 0x89+3;
         sbit M01    = 0x89+4;
         sbit M11    = 0x89+5;
         sbit CT1    = 0x89+6;
         sbit GATE1  = 0x89+7;
//sfr TL0     = 0x8A;
//sfr TL1     = 0x8B;
//sfr TH0     = 0x8C;
//sfr TH1     = 0x8D;
sfr CKCON  = 0x8E;
         /*  CKCON */
         sbit MD0    = 0x8E+0;
         sbit MD1    = 0x8E+1;
         sbit MD2    = 0x8E+2;
         sbit T0M   = 0x8E+3;
         sbit T1M   = 0x8E+4;
         sbit T2M   = 0x8E+5;
sfr SPC_FNC = 0x8F; // Was WRS in Reg320
         /*  SPC_FNC */
         sbit WRS   = 0x8F+0;
sfr EXIF   = 0x91; // EXIF Bit Values differ from Reg320
         /*  EXIF */
         sbit USBINT = 0x91+4;
         sbit I2CINT = 0x91+5;
         sbit IE4    = 0x91+6;
         sbit IE5    = 0x91+7;
sfr MPAGE = 0x92;
sfr SCON0  = 0x98;
         /*  SCON0  */
/*         sbit RI   = 0x98+0;
         sbit TI   = 0x98+1;
         sbit RB8   = 0x98+2;
         sbit TB8   = 0x98+3;
         sbit REN  = 0x98+4;
         sbit SM2   = 0x98+5;
         sbit SM1   = 0x98+6;
         sbit SM0   = 0x98+7;   */
sfr SBUF0  = 0x99;
//sfr IE    = 0xA8;
         /*  IE */
/*         sbit EX0   = 0xA8+0;
         sbit ET0   = 0xA8+1;
         sbit EX1   = 0xA8+2;
         sbit ET1   = 0xA8+3;
         sbit ES0   = 0xA8+4;
         sbit ET2   = 0xA8+5;
         sbit ES1   = 0xA8+6;
         sbit EA   = 0xA8+7;   */
//sfr IP    = 0xB8;
         /*  IP */
/*         sbit PX0   = 0xB8+0;
         sbit PT0   = 0xB8+1;
         sbit PX1   = 0xB8+2;
         sbit PT1   = 0xB8+3;   */
         sbit PS0   = 0xB8+4;
//         sbit PT2   = 0xB8+5;
         sbit PS1   = 0xB8+6;
sfr SCON1  = 0xC0;
         /*  SCON1  */
         sbit RI1   = 0xC0+0;
         sbit TI1   = 0xC0+1;
         sbit RB81  = 0xC0+2;
         sbit TB81  = 0xC0+3;
         sbit REN1  = 0xC0+4;
         sbit SM21  = 0xC0+5;
         sbit SM11  = 0xC0+6;
         sbit SM01  = 0xC0+7;
sfr SBUF1  = 0xC1;
//sfr T2CON = 0xC8;
         /*  T2CON */
/*         sbit CP_RL2 = 0xC8+0;
         sbit C_T2  = 0xC8+1;
         sbit TR2   = 0xC8+2;
         sbit EXEN2 = 0xC8+3;
         sbit TCLK = 0xC8+4;
         sbit RCLK = 0xC8+5;
         sbit EXF2  = 0xC8+6;
         sbit TF2   = 0xC8+7;
sfr RCAP2L = 0xCA;
sfr RCAP2H = 0xCB;
sfr TL2    = 0xCC;
sfr TH2    = 0xCD;
sfr PSW   = 0xD0;   */
         /*  PSW */
/*         sbit P    = 0xD0+0;
         sbit FL   = 0xD0+1;
         sbit OV   = 0xD0+2;
         sbit RS0   = 0xD0+3;
         sbit RS1   = 0xD0+4;
         sbit F0    = 0xD0+5;
         sbit AC   = 0xD0+6;
         sbit CY   = 0xD0+7;   */
sfr EICON = 0xD8; // Was WDCON in DS80C320; Bit Values differ from Reg320
         /*  EICON */
         sbit INT6  = 0xD8+3;
         sbit RESI = 0xD8+4;
         sbit ERESI = 0xD8+5;
         sbit SMOD1 = 0xD8+7;
//sfr ACC   = 0xE0;
sfr EIE   = 0xE8; // EIE Bit Values differ from Reg320
                        /*  EIE */
         sbit EUSB   = 0xE8+0;
         sbit EI2C   = 0xE8+1;
         sbit EIEX4   = 0xE8+2;
         sbit EIEX5   = 0xE8+3;
         sbit EIEX6   = 0xE8+4;
//sfr B     = 0xF0;
sfr EIP   = 0xF8; // EIP Bit Values differ from Reg320
                        /*  EIP */
         sbit PUSB   = 0xF8+0;
         sbit PI2C   = 0xF8+1;
         sbit EIPX4   = 0xF8+2;
         sbit EIPX5   = 0xF8+3;
         sbit EIPX6   = 0xF8+4;

/*-----------------------------------------------------------------------------
   Bit Masks
-----------------------------------------------------------------------------*/

/* CPU Control & Status Register */
#define bmCHIPREV      (bmBIT7 | bmBIT6 | bmBIT5 | bmBIT4)
#define bmCLK24OE      bmBIT1
#define bm8052RES      bmBIT0
/* Port Configuration Registers */
/* Port A */
#define bmRXD1OUT      bmBIT7
#define bmRXD0OUT      bmBIT6
#define bmFRD         bmBIT5
#define bmFWR         bmBIT4
#define bmCS         bmBIT3
#define bmOE         bmBIT2
#define bmT1OUT         bmBIT1
#define bmT0OUT         bmBIT0
/* Port B */
#define bmT2OUT         bmBIT7
#define bmINT6         bmBIT6
#define bmINT5         bmBIT5
#define bmINT4         bmBIT4
#define bmTXD1         bmBIT3
#define bmRXD1         bmBIT2
#define bmT2EX         bmBIT1
#define bmT2         bmBIT0
/* Port C */
#define bmRD         bmBIT7
#define bmWR         bmBIT6
#define bmT1         bmBIT5
#define bmT0         bmBIT4
#define bmINT1         bmBIT3
#define bmINT0         bmBIT2
#define bmTXD0         bmBIT1
#define bmRXD0         bmBIT0
/* Isochronous Status & End Point Valid Registers */
#define bmEP15         bmBIT7
#define bmEP14         bmBIT6
#define bmEP13         bmBIT5
#define bmEP12         bmBIT4
#define bmEP11         bmBIT3
#define bmEP10         bmBIT2
#define bmEP9         bmBIT1
#define bmEP8         bmBIT0
/* I2C Control & Status Register */
#define bmSTART         bmBIT7
#define bmSTOP         bmBIT6
#define bmLASTRD      bmBIT5
#define bmID         (bmBIT4 | bmBIT3)
#define bmBERR         bmBIT2
#define bmACK         bmBIT1
#define bmDONE         bmBIT0
/* Interrupt Vector Register */
#define bmIV4         bmBIT6
#define bmIV3         bmBIT5
#define bmIV2         bmBIT4
#define bmIV1         bmBIT3
#define bmIV0         bmBIT2
/* End point Interrupt Request, End Point Interrupt Enable */
/* And End Point Valid Registers */
#define bmEP7         bmBIT7
#define bmEP6         bmBIT6
#define bmEP5         bmBIT5
#define bmEP4         bmBIT4
#define bmEP3         bmBIT3
#define bmEP2         bmBIT2
#define bmEP1         bmBIT1
#define bmEP0         bmBIT0
/* Global Interrupt Request & Enable Registers */
#define bmIBN       bmBIT5
#define bmURES         bmBIT4
#define bmSUSP         bmBIT3
#define bmSUTOK         bmBIT2
#define bmSOF         bmBIT1
#define bmSUDAV         bmBIT0
/* Global Control */
#define bmBREAK         bmBIT3
#define bmBPPULSE      bmBIT2
#define bmBPEN         bmBIT1
#define bmAVEN         bmBIT0
/* USB Control & Status Register */
#define bmRWAKEUP      bmBIT7
#define bmDISCON      bmBIT3
#define bmDISCOE      bmBIT2
#define bmRENUM         bmBIT1
#define bmSIGRESUME      bmBIT0
/* End Point 0 Control & Status Register */
#define bmOUT         bmBIT3
#define bmIN         bmBIT2
#define bmHS         bmBIT1
#define bmHSSTALL      bmBIT0
/* End Point Control & Status Registers */
#define bmEPSTALL      bmBIT0
#define bmEPBUSY      bmBIT1
/* Fast Transfer Register */
#define bmFISO         bmBIT7
#define bmFBLK         bmBIT6
#define bmRPOL         bmBIT5
#define bmRMOD1         bmBIT4
#define bmRMOD0         bmBIT3
#define bmWPOL         bmBIT2
#define bmWMOD1         bmBIT1
#define bmWMOD0         bmBIT0
/* Endpoint Pairing Register */
#define bmISOSEND0      bmBIT7
#define bmPR6OUT      bmBIT5
#define bmPR4OUT      bmBIT4
#define bmPR2OUT      bmBIT3
#define bmPR6IN         bmBIT2
#define bmPR4IN         bmBIT1
#define bmPR2IN         bmBIT0
/* End point control offsets */
enum
{
   IN0BUF_ID = 0,
   IN1BUF_ID,
   IN2BUF_ID,
   IN3BUF_ID,
   IN4BUF_ID,
   IN5BUF_ID,
   IN6BUF_ID,
   IN7BUF_ID,
   OUT0BUF_ID,
   OUT1BUF_ID,
   OUT2BUF_ID,
   OUT3BUF_ID,
   OUT4BUF_ID,
   OUT5BUF_ID,
   OUT6BUF_ID,
   OUT7BUF_ID
};

#define EP0CS   EPIO[0].cntrl
#define IN0BC   EPIO[0].bytes
#define IN1CS   EPIO[1].cntrl
#define IN1BC   EPIO[1].bytes
#define IN2CS   EPIO[2].cntrl
#define IN2BC   EPIO[2].bytes
#define IN3CS   EPIO[3].cntrl
#define IN3BC   EPIO[3].bytes
#define IN4CS   EPIO[4].cntrl
#define IN4BC   EPIO[4].bytes
#define IN5CS   EPIO[5].cntrl
#define IN5BC   EPIO[5].bytes
#define IN6CS   EPIO[6].cntrl
#define IN6BC   EPIO[6].bytes
#define IN7CS   EPIO[7].cntrl
#define IN7BC   EPIO[7].bytes
#define OUT0CS   EPIO[8].cntrl
#define OUT0BC   EPIO[8].bytes
#define OUT1CS   EPIO[9].cntrl
#define OUT1BC   EPIO[9].bytes
#define OUT2CS   EPIO[10].cntrl
#define OUT2BC   EPIO[10].bytes
#define OUT3CS   EPIO[11].cntrl
#define OUT3BC   EPIO[11].bytes
#define OUT4CS   EPIO[12].cntrl
#define OUT4BC   EPIO[12].bytes
#define OUT5CS   EPIO[13].cntrl
#define OUT5BC   EPIO[13].bytes
#define OUT6CS   EPIO[14].cntrl
#define OUT6BC   EPIO[14].bytes
#define OUT7CS   EPIO[15].cntrl
#define OUT7BC   EPIO[15].bytes

/*-----------------------------------------------------------------------------
   Macros
-----------------------------------------------------------------------------*/
/* Convert End point ID (d0000eee) to EPIO offset */
#define EPID(id)      (((~id & 0x80) >> 4) + (id & 0x07))


#endif   /* EZREGS_H */
Gruß,
Elko
Keyboard not found. Press any key to continue.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:09 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz