blob: 9c454fb1c8389730e209492c404327109fdb5729 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
wdenke2211742002-11-02 23:30:20 +00002/*
Simon Glassec1fa182019-08-02 09:44:27 -06003 * Common header file for U-Boot
4 *
5 * This file still includes quite a bit of stuff that should be in separate
6 * headers like command.h, cpu.h and timer.h. Please think before adding more
7 * things. Patches to remove things are welcome.
8 *
Wolfgang Denk3b74e7e2009-05-16 10:47:45 +02009 * (C) Copyright 2000-2009
wdenke2211742002-11-02 23:30:20 +000010 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
wdenke2211742002-11-02 23:30:20 +000011 */
12
13#ifndef __COMMON_H_
Wolfgang Denkd0b8fee2012-01-06 07:36:44 +010014#define __COMMON_H_ 1
wdenke2211742002-11-02 23:30:20 +000015
Wolfgang Denkfcd3c872009-07-24 00:17:48 +020016#ifndef __ASSEMBLY__ /* put C only stuff in this section */
17
wdenke2211742002-11-02 23:30:20 +000018typedef unsigned char uchar;
19typedef volatile unsigned long vu_long;
wdenk180d3f72004-01-04 16:28:35 +000020typedef volatile unsigned short vu_short;
wdenke2211742002-11-02 23:30:20 +000021typedef volatile unsigned char vu_char;
22
23#include <config.h>
Joe Hershberger2307ea42016-04-04 04:07:33 -050024#include <errno.h>
Masahiro Yamadaa7b81762016-12-28 00:36:00 +090025#include <time.h>
Wolfgang Denk25ddd1f2010-10-26 14:34:52 +020026#include <asm-offsets.h>
wdenke2211742002-11-02 23:30:20 +000027#include <linux/bitops.h>
Masahiro Yamada0a70fb42017-09-16 14:10:45 +090028#include <linux/bug.h>
Masahiro Yamada5bc516e2016-12-28 00:35:59 +090029#include <linux/delay.h>
wdenke2211742002-11-02 23:30:20 +000030#include <linux/types.h>
Masahiro Yamadab44b3022017-09-16 14:10:40 +090031#include <linux/printk.h>
wdenke2211742002-11-02 23:30:20 +000032#include <linux/string.h>
Marek Vasut9aed5082012-09-27 17:08:15 +020033#include <linux/stringify.h>
wdenke2211742002-11-02 23:30:20 +000034#include <asm/ptrace.h>
35#include <stdarg.h>
Masahiro Yamada7fea7b12017-09-16 14:10:39 +090036#include <stdio.h>
Masahiro Yamadacba1da42014-11-07 03:03:28 +090037#include <linux/kernel.h>
Simon Glass85043152017-05-17 08:23:05 -060038
wdenke2211742002-11-02 23:30:20 +000039#include <part.h>
40#include <flash.h>
41#include <image.h>
42
York Sun4d1fd7f2014-02-26 17:03:19 -080043#ifdef __LP64__
44#define CONFIG_SYS_SUPPORT_64BIT_DATA
45#endif
46
Simon Glass0e98b0a2017-12-04 13:48:20 -070047#include <log.h>
Simon Glass21726a72011-06-29 09:49:34 +000048
wdenkc83bf6a2004-01-06 22:38:14 +000049typedef void (interrupt_handler_t)(void *);
wdenke2211742002-11-02 23:30:20 +000050
wdenkc83bf6a2004-01-06 22:38:14 +000051#include <asm/u-boot.h> /* boot information for Linux kernel */
wdenke2211742002-11-02 23:30:20 +000052#include <asm/global_data.h> /* global data used for startup functions */
53
Patrick Delaunayd6f87712018-03-13 13:57:00 +010054/* startup functions, used in:
55 * common/board_f.c
Patrick Delaunay11f86cb2018-03-13 13:57:01 +010056 * common/init/board_init.c
Patrick Delaunaye2c219c2018-03-13 13:57:02 +010057 * common/board_r.c
Patrick Delaunayfc22ee22018-03-13 13:57:03 +010058 * common/board_info.c
Patrick Delaunayd6f87712018-03-13 13:57:00 +010059 */
Patrick Delaunaydafa84d2018-03-09 18:28:12 +010060#include <init.h>
61
wdenkc7de8292002-11-19 11:04:11 +000062/*
wdenke2211742002-11-02 23:30:20 +000063 * Function Prototypes
64 */
wdenkc83bf6a2004-01-06 22:38:14 +000065void hang (void) __attribute__ ((noreturn));
wdenke2211742002-11-02 23:30:20 +000066
Wolfgang Denkf6c019c2011-07-30 12:32:45 +000067int cpu_init(void);
68
Simon Glass2ea09c82015-04-28 20:25:07 -060069#include <display_options.h>
wdenke2211742002-11-02 23:30:20 +000070
71/* common/main.c */
72void main_loop (void);
Simon Glass009dde12012-02-14 19:59:20 +000073int run_command(const char *cmd, int flag);
Thomas Betker1d43bfd2014-06-05 20:07:57 +020074int run_command_repeatable(const char *cmd, int flag);
Simon Glassd51004a2012-03-30 21:30:55 +000075
76/**
77 * Run a list of commands separated by ; or even \0
78 *
79 * Note that if 'len' is not -1, then the command does not need to be nul
80 * terminated, Memory will be allocated for the command in that case.
81 *
82 * @param cmd List of commands to run, each separated bu semicolon
83 * @param len Length of commands excluding terminator if known (-1 if not)
84 * @param flag Execution flags (CMD_FLAG_...)
85 * @return 0 on success, or != 0 on error.
86 */
87int run_command_list(const char *cmd, int len, int flag);
wdenke2211742002-11-02 23:30:20 +000088
Patrick Delaunaye2c219c2018-03-13 13:57:02 +010089int checkflash(void);
90int checkdram(void);
Masahiro Yamada6ab6b2a2014-02-05 11:28:25 +090091extern u8 __dtb_dt_begin[]; /* embedded device tree blob */
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000092extern u8 __dtb_dt_spl_begin[]; /* embedded device tree blob for SPL/TPL */
Patrick Delaunayd6f87712018-03-13 13:57:00 +010093int mdm_init(void);
wdenke2211742002-11-02 23:30:20 +000094
Simon Glass15a33e42012-11-30 13:01:20 +000095/**
96 * Show the DRAM size in a board-specific way
97 *
98 * This is used by boards to display DRAM information in their own way.
99 *
100 * @param size Size of DRAM (which should be displayed along with other info)
101 */
Andrew Bradfordea11b402015-05-22 08:30:14 -0400102void board_show_dram(phys_size_t size);
Simon Glass15a33e42012-11-30 13:01:20 +0000103
Simon Glass13d06982013-05-08 08:06:01 +0000104/**
Alexander Graf7b78d642018-11-30 21:24:56 +0100105 * Get the uppermost pointer that is valid to access
106 *
107 * Some systems may not map all of their address space. This function allows
108 * boards to indicate what their highest support pointer value is for DRAM
109 * access.
110 *
111 * @param total_size Size of U-Boot (unused?)
112 */
113ulong board_get_usable_ram_top(ulong total_size);
114
115/**
Ma Haijune29607e2014-07-12 14:24:06 +0100116 * arch_fixup_fdt() - Write arch-specific information to fdt
Simon Glass13d06982013-05-08 08:06:01 +0000117 *
Ma Haijune29607e2014-07-12 14:24:06 +0100118 * Defined in arch/$(ARCH)/lib/bootm-fdt.c
Simon Glass13d06982013-05-08 08:06:01 +0000119 *
120 * @blob: FDT blob to write to
121 * @return 0 if ok, or -ve FDT_ERR_... on failure
122 */
Ma Haijune29607e2014-07-12 14:24:06 +0100123int arch_fixup_fdt(void *blob);
Simon Glass13d06982013-05-08 08:06:01 +0000124
wdenke2211742002-11-02 23:30:20 +0000125/* common/flash.c */
126void flash_perror (int);
127
Wolfgang Denk74de7ae2009-04-01 23:34:12 +0200128/* common/cmd_source.c */
129int source (ulong addr, const char *fit_uname);
wdenke2211742002-11-02 23:30:20 +0000130
wdenkc83bf6a2004-01-06 22:38:14 +0000131extern ulong load_addr; /* Default Load Address */
Simon Glass1aec2442011-10-21 18:51:38 +0000132extern ulong save_addr; /* Default Save Address */
133extern ulong save_size; /* Default Save Size */
wdenke2211742002-11-02 23:30:20 +0000134
Jason Hobbs06283a62011-08-31 10:37:30 -0500135/* common/cmd_net.c */
136int do_tftpb(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);
137
Rob Herring669df7e2012-05-25 10:47:39 +0000138/* common/cmd_fat.c */
139int do_fat_fsload(cmd_tbl_t *, int, int, char * const []);
140
141/* common/cmd_ext2.c */
142int do_ext2load(cmd_tbl_t *, int, int, char * const []);
143
wdenkc83bf6a2004-01-06 22:38:14 +0000144void pci_init_board(void);
wdenke2211742002-11-02 23:30:20 +0000145
wdenk27b207f2003-07-24 23:38:38 +0000146/* common/exports.c */
147void jumptable_init(void);
148
Mike Frysingerecb1dc82009-05-20 04:35:14 -0400149/* common/kallsysm.c */
150const char *symbol_lookup(unsigned long addr, unsigned long *caddr);
151
wdenkc83bf6a2004-01-06 22:38:14 +0000152/* common/memsize.c */
Albert ARIBAUDa55d23c2011-07-03 05:55:33 +0000153long get_ram_size (long *, long);
York Sune3866162014-02-11 11:57:26 -0800154phys_size_t get_effective_memsize(void);
wdenkc83bf6a2004-01-06 22:38:14 +0000155
wdenke2211742002-11-02 23:30:20 +0000156/* $(BOARD)/$(BOARD).c */
157void reset_phy (void);
wdenkc83bf6a2004-01-06 22:38:14 +0000158void fdc_hw_init (void);
wdenke2211742002-11-02 23:30:20 +0000159
160/* $(BOARD)/eeprom.c */
Simon Glasseb5ba3a2017-05-12 21:09:49 -0600161#ifdef CONFIG_CMD_EEPROM
Marek Vasut354e3ed2015-11-10 20:53:31 +0100162void eeprom_init (int bus);
wdenke2211742002-11-02 23:30:20 +0000163int eeprom_read (unsigned dev_addr, unsigned offset, uchar *buffer, unsigned cnt);
164int eeprom_write (unsigned dev_addr, unsigned offset, uchar *buffer, unsigned cnt);
Simon Glasseb5ba3a2017-05-12 21:09:49 -0600165#else
166/*
167 * Some EEPROM code is depecated because it used the legacy I2C interface. Add
168 * some macros here so we don't have to touch every one of those uses
169 */
170#define eeprom_init(bus)
171#define eeprom_read(dev_addr, offset, buffer, cnt) ((void)-ENOSYS)
172#define eeprom_write(dev_addr, offset, buffer, cnt) ((void)-ENOSYS)
173#endif
wdenke2211742002-11-02 23:30:20 +0000174
Adam Fordf1b1f772018-04-15 13:51:26 -0400175#if !defined(CONFIG_ENV_EEPROM_IS_ON_I2C) && defined(CONFIG_SYS_I2C_EEPROM_ADDR)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200176# define CONFIG_SYS_DEF_EEPROM_ADDR CONFIG_SYS_I2C_EEPROM_ADDR
Heiko Schocher548738b2010-01-07 08:55:40 +0100177#endif
wdenke2211742002-11-02 23:30:20 +0000178
wdenke2211742002-11-02 23:30:20 +0000179/* $(BOARD)/$(BOARD).c */
wdenkc837dcb2004-01-20 23:12:12 +0000180int board_early_init_f (void);
mario.six@gdsys.cc2a792752017-02-22 16:07:22 +0100181int board_fix_fdt (void *rw_fdt_blob); /* manipulate the U-Boot fdt before its relocation */
wdenkc837dcb2004-01-20 23:12:12 +0000182int board_late_init (void);
wdenke2211742002-11-02 23:30:20 +0000183int board_postclk_init (void); /* after clocks/timebase, before env/serial */
wdenkc837dcb2004-01-20 23:12:12 +0000184int board_early_init_r (void);
wdenke2211742002-11-02 23:30:20 +0000185
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200186#if defined(CONFIG_SYS_DRAM_TEST)
wdenke2211742002-11-02 23:30:20 +0000187int testdram(void);
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200188#endif /* CONFIG_SYS_DRAM_TEST */
wdenke2211742002-11-02 23:30:20 +0000189
190/* $(CPU)/start.S */
wdenke2211742002-11-02 23:30:20 +0000191int icache_status (void);
192void icache_enable (void);
193void icache_disable(void);
194int dcache_status (void);
195void dcache_enable (void);
196void dcache_disable(void);
Aneesh V2c451f72011-06-16 23:30:47 +0000197void mmu_disable(void);
Benoît Thébaudeau5c6db122013-04-11 09:35:53 +0000198#if defined(CONFIG_ARM)
199void relocate_code(ulong);
200#else
201void relocate_code(ulong, gd_t *, ulong) __attribute__ ((noreturn));
Benoît Thébaudeau959eaa72013-04-11 09:35:43 +0000202#endif
wdenke2211742002-11-02 23:30:20 +0000203ulong get_endaddr (void);
204void trap_init (ulong);
Simon Glass6e2941d2017-05-17 08:23:06 -0600205
wdenke2211742002-11-02 23:30:20 +0000206/* $(CPU)/cpu.c */
Timur Tabifbb9ecf2011-08-05 16:15:24 -0500207static inline int cpumask_next(int cpu, unsigned int mask)
208{
209 for (cpu++; !((1 << cpu) & mask); cpu++)
210 ;
211
212 return cpu;
213}
214
215#define for_each_cpu(iter, cpu, num_cpus, mask) \
216 for (iter = 0, cpu = cpumask_next(-1, mask); \
217 iter < num_cpus; \
218 iter++, cpu = cpumask_next(cpu, mask)) \
219
Poonam Aggrwal0e870982009-07-31 12:08:14 +0530220int cpu_numcores (void);
Shaveta Leekhab8bf0ad2015-01-19 12:46:54 +0530221int cpu_num_dspcores(void);
Timur Tabifbb9ecf2011-08-05 16:15:24 -0500222u32 cpu_mask (void);
Shaveta Leekhab8bf0ad2015-01-19 12:46:54 +0530223u32 cpu_dsp_mask(void);
Timur Tabifbb9ecf2011-08-05 16:15:24 -0500224int is_core_valid (unsigned int);
Simon Glasscbcbf712017-01-23 13:31:22 -0700225
Diego Dorta026d7952017-10-05 09:13:38 -0300226void s_init(void);
227
wdenke2211742002-11-02 23:30:20 +0000228int checkcpu (void);
229int checkicache (void);
230int checkdcache (void);
231void upmconfig (unsigned int, unsigned int *, unsigned int);
232ulong get_tbclk (void);
Przemyslaw Marczak1fb4dab2014-09-01 13:50:48 +0200233void reset_misc (void);
wdenk3ec924a2005-04-03 17:23:39 +0000234void reset_cpu (ulong addr);
Kim Phillips6a16e0d2007-08-15 22:30:26 -0500235void ft_cpu_setup(void *blob, bd_t *bd);
Kim Phillips6a16e0d2007-08-15 22:30:26 -0500236void ft_pci_setup(void *blob, bd_t *bd);
Kim Phillips6a16e0d2007-08-15 22:30:26 -0500237
Andre Przywaraba6a1692013-09-19 18:06:44 +0200238void smp_set_core_boot_addr(unsigned long addr, int corenr);
239void smp_kick_all_cpus(void);
wdenke2211742002-11-02 23:30:20 +0000240
241/* $(CPU)/serial.c */
242int serial_init (void);
243void serial_setbrg (void);
244void serial_putc (const char);
wdenk756f5862005-04-03 15:51:42 +0000245void serial_putc_raw(const char);
wdenke2211742002-11-02 23:30:20 +0000246void serial_puts (const char *);
wdenke2211742002-11-02 23:30:20 +0000247int serial_getc (void);
248int serial_tstc (void);
249
250/* $(CPU)/speed.c */
251int get_clocks (void);
wdenke2211742002-11-02 23:30:20 +0000252ulong get_bus_freq (ulong);
Stefan Roese550650d2010-09-20 16:05:31 +0200253int get_serial_clock(void);
wdenke2211742002-11-02 23:30:20 +0000254
wdenke2211742002-11-02 23:30:20 +0000255/* $(CPU)/interrupts.c */
wdenkc83bf6a2004-01-06 22:38:14 +0000256int interrupt_init (void);
257void timer_interrupt (struct pt_regs *);
wdenke2211742002-11-02 23:30:20 +0000258void external_interrupt (struct pt_regs *);
259void irq_install_handler(int, interrupt_handler_t *, void *);
260void irq_free_handler (int);
261void reset_timer (void);
Simon Glassb2e16a82013-06-11 11:14:39 -0700262
263/* Return value of monotonic microsecond timer */
264unsigned long timer_get_us(void);
265
wdenke2211742002-11-02 23:30:20 +0000266void enable_interrupts (void);
267int disable_interrupts (void);
268
269/* $(CPU)/.../commproc.c */
wdenkbdccc4f2003-08-05 17:43:17 +0000270void bootcount_store (ulong);
271ulong bootcount_load (void);
wdenke2211742002-11-02 23:30:20 +0000272
273/* $(CPU)/.../<eth> */
Wolfgang Denkc5bded32007-08-29 14:05:30 +0200274void mii_init (void);
wdenke2211742002-11-02 23:30:20 +0000275
Peter Tyserea0364f2010-04-12 22:28:04 -0500276/* arch/$(ARCH)/lib/cache.c */
Aneesh Vcba4b182011-08-16 04:33:05 +0000277void enable_caches(void);
wdenke2211742002-11-02 23:30:20 +0000278void flush_cache (unsigned long, unsigned long);
Aneesh V2c451f72011-06-16 23:30:47 +0000279void flush_dcache_all(void);
Stefan Roese03d3bfb2009-01-21 17:20:20 +0100280void flush_dcache_range(unsigned long start, unsigned long stop);
281void invalidate_dcache_range(unsigned long start, unsigned long stop);
Aneesh V2c451f72011-06-16 23:30:47 +0000282void invalidate_dcache_all(void);
283void invalidate_icache_all(void);
wdenk0db5bca2003-03-31 17:27:09 +0000284
Simon Glass4d24a112015-05-13 07:02:25 -0600285enum {
286 /* Disable caches (else flush caches but leave them active) */
287 CBL_DISABLE_CACHES = 1 << 0,
288 CBL_SHOW_BOOTSTAGE_REPORT = 1 << 1,
289
290 CBL_ALL = 3,
291};
292
293/**
294 * Clean up ready for linux
295 *
296 * @param flags Flags to control what is done
297 */
298int cleanup_before_linux_select(int flags);
299
Peter Tyserea0364f2010-04-12 22:28:04 -0500300/* arch/$(ARCH)/lib/ticks.S */
Simon Glass19ea4672014-10-15 04:38:33 -0600301uint64_t get_ticks(void);
wdenke2211742002-11-02 23:30:20 +0000302void wait_ticks (unsigned long);
303
Peter Tyserea0364f2010-04-12 22:28:04 -0500304/* arch/$(ARCH)/lib/time.c */
wdenke2211742002-11-02 23:30:20 +0000305ulong usec2ticks (unsigned long usec);
306ulong ticks2usec (unsigned long ticks);
wdenke2211742002-11-02 23:30:20 +0000307
Julius Werner027b7282015-10-06 20:03:53 -0700308/* lib/lz4_wrapper.c */
309int ulz4fn(const void *src, size_t srcn, void *dst, size_t *dstn);
310
Wolfgang Denk54c69772010-06-13 01:45:10 +0200311/* lib/qsort.c */
312void qsort(void *base, size_t nmemb, size_t size,
313 int(*compar)(const void *, const void *));
Mike Frysinger560d4242010-12-17 16:51:59 -0500314int strcmp_compar(const void *, const void *);
Wolfgang Denk54c69772010-06-13 01:45:10 +0200315
Jason Hobbse11938e2011-08-23 11:06:56 +0000316/* lib/uuid.c */
Przemyslaw Marczakd718ded2014-04-02 10:20:03 +0200317#include <uuid.h>
Jason Hobbse11938e2011-08-23 11:06:56 +0000318
Peter Tyser78acc472010-04-12 22:28:05 -0500319/* lib/vsprintf.c */
Simon Glass9785c902011-11-02 09:52:07 +0000320#include <vsprintf.h>
wdenke2211742002-11-02 23:30:20 +0000321
Peter Tyser78acc472010-04-12 22:28:05 -0500322/* lib/strmhz.c */
Ed Swarthout55f79342011-03-05 10:28:17 -0600323char * strmhz(char *buf, unsigned long hz);
Haavard Skinnemoen0768b7a2008-08-18 13:41:27 +0200324
wdenke2211742002-11-02 23:30:20 +0000325/*
326 * STDIO based functions (can always be used)
327 */
wdenke2211742002-11-02 23:30:20 +0000328/* serial stuff */
Wolfgang Denkd9c27252010-06-20 17:14:14 +0200329int serial_printf (const char *fmt, ...)
Andrew Klossnerdc4b0b32008-07-07 06:41:14 -0700330 __attribute__ ((format (__printf__, 1, 2)));
wdenke2211742002-11-02 23:30:20 +0000331
Joe Hershberger4ef8d532012-05-23 08:01:04 +0000332/* lib/net_utils.c */
333#include <net.h>
Simon Glass723806c2017-08-03 12:22:15 -0600334static inline struct in_addr env_get_ip(char *var)
Joe Hershberger4ef8d532012-05-23 08:01:04 +0000335{
Simon Glass00caae62017-08-03 12:22:12 -0600336 return string_to_ip(env_get(var));
Joe Hershberger4ef8d532012-05-23 08:01:04 +0000337}
338
Simon Glass097e1782012-01-14 15:24:44 +0000339#include <bootstage.h>
wdenke2211742002-11-02 23:30:20 +0000340
Andre Przywara2a6713b2017-01-02 11:48:30 +0000341#else /* __ASSEMBLY__ */
342
Andre Przywara2a6713b2017-01-02 11:48:30 +0000343#endif /* __ASSEMBLY__ */
Wolfgang Denkfcd3c872009-07-24 00:17:48 +0200344
345/* Put only stuff here that the assembler can digest */
346
347#ifdef CONFIG_POST
348#define CONFIG_HAS_POST
Michael Zaidman800eb092010-09-20 08:51:53 +0200349#ifndef CONFIG_POST_ALT_LIST
350#define CONFIG_POST_STD_LIST
351#endif
Wolfgang Denkfcd3c872009-07-24 00:17:48 +0200352#endif
353
Anton Staaf155cfb52011-09-02 13:45:28 +0000354#define ROUND(a,b) (((a) + (b) - 1) & ~((b) - 1))
Andy Fleming4b03ac82008-06-16 13:58:53 -0500355
Anton Staaf1e41f5a2011-10-17 16:46:13 -0700356/*
Simon Glassc9689ca2015-06-23 15:38:31 -0600357 * check_member() - Check the offset of a structure member
358 *
359 * @structure: Name of structure (e.g. global_data)
360 * @member: Name of member (e.g. baudrate)
361 * @offset: Expected offset in bytes
362 */
363#define check_member(structure, member, offset) _Static_assert( \
364 offsetof(struct structure, member) == offset, \
365 "`struct " #structure "` offset for `" #member "` is not " #offset)
366
Simon Glass476476e2015-08-04 12:33:52 -0600367/* Avoid using CONFIG_EFI_STUB directly as we may boot from other loaders */
368#ifdef CONFIG_EFI_STUB
369#define ll_boot_init() false
370#else
371#define ll_boot_init() true
372#endif
373
Mike Frysingerc3eb3fe2011-07-08 10:44:25 +0000374/* Pull in stuff for the build system */
375#ifdef DO_DEPS_ONLY
Simon Glassf3998fd2019-08-02 09:44:25 -0600376# include <env_internal.h>
Mike Frysingerc3eb3fe2011-07-08 10:44:25 +0000377#endif
378
wdenke2211742002-11-02 23:30:20 +0000379#endif /* __COMMON_H_ */