151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef __cris_defs_asm_h
251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define __cris_defs_asm_h
351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/*
551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik * This file is autogenerated from
651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik *   file:           ../../inst/crisp/doc/cris.r
751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik *     id:           cris.r,v 1.6 2004/05/05 07:41:12 perz Exp
851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik *     last modfied: Mon Apr 11 16:06:39 2005
951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik *
1051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik *   by /n/asic/design/tools/rdesc/src/rdes2c -asm --outfile asm/cris_defs_asm.h ../../inst/crisp/doc/cris.r
1151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik *      id: $Id: cris_defs_asm.h,v 1.1 2005/04/24 18:31:04 starvik Exp $
1251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik * Any changes here will be lost.
1351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik *
1451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik * -*- buffer-read-only: t -*-
1551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik */
1651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
1751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef REG_FIELD
1851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_FIELD( scope, reg, field, value ) \
1951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik  REG_FIELD_X_( value, reg_##scope##_##reg##___##field##___lsb )
2051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_FIELD_X_( value, shift ) ((value) << shift)
2151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif
2251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
2351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef REG_STATE
2451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_STATE( scope, reg, field, symbolic_value ) \
2551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik  REG_STATE_X_( regk_##scope##_##symbolic_value, reg_##scope##_##reg##___##field##___lsb )
2651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_STATE_X_( k, shift ) (k << shift)
2751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif
2851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
2951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef REG_MASK
3051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_MASK( scope, reg, field ) \
3151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik  REG_MASK_X_( reg_##scope##_##reg##___##field##___width, reg_##scope##_##reg##___##field##___lsb )
3251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_MASK_X_( width, lsb ) (((1 << width)-1) << lsb)
3351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif
3451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
3551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef REG_LSB
3651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_LSB( scope, reg, field ) reg_##scope##_##reg##___##field##___lsb
3751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif
3851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
3951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef REG_BIT
4051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_BIT( scope, reg, field ) reg_##scope##_##reg##___##field##___bit
4151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif
4251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
4351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef REG_ADDR
4451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_ADDR( scope, inst, reg ) REG_ADDR_X_(inst, reg_##scope##_##reg##_offset)
4551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_ADDR_X_( inst, offs ) ((inst) + offs)
4651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif
4751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
4851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#ifndef REG_ADDR_VECT
4951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_ADDR_VECT( scope, inst, reg, index ) \
5051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik         REG_ADDR_VECT_X_(inst, reg_##scope##_##reg##_offset, index, \
5151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik			 STRIDE_##scope##_##reg )
5251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define REG_ADDR_VECT_X_( inst, offs, index, stride ) \
5351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik                          ((inst) + offs + (index) * stride)
5451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif
5551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
5651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_cfg, scope cris, type rw */
5751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___ic___lsb 0
5851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___ic___width 1
5951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___ic___bit 0
6051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___dc___lsb 1
6151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___dc___width 1
6251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___dc___bit 1
6351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___im___lsb 2
6451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___im___width 1
6551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___im___bit 2
6651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___dm___lsb 3
6751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___dm___width 1
6851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___dm___bit 3
6951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gb___lsb 4
7051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gb___width 1
7151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gb___bit 4
7251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gk___lsb 5
7351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gk___width 1
7451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gk___bit 5
7551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gp___lsb 6
7651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gp___width 1
7751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg___gp___bit 6
7851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_cfg_offset 0
7951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
8051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_ccs, scope cris, type rw */
8151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_ccs_offset 4
8251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
8351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_srs, scope cris, type rw */
8451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_srs___srs___lsb 0
8551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_srs___srs___width 8
8651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_srs_offset 8
8751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
8851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_nrp, scope cris, type rw */
8951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_nrp_offset 12
9051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
9151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_exs, scope cris, type rw */
9251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_exs_offset 16
9351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
9451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_eda, scope cris, type rw */
9551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_eda_offset 20
9651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
9751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_r0, scope cris, type rw */
9851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_r0_offset 32
9951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
10051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_r1, scope cris, type rw */
10151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_r1_offset 36
10251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
10351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_r2, scope cris, type rw */
10451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_r2_offset 40
10551533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
10651533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Register rw_gc_r3, scope cris, type rw */
10751533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define reg_cris_rw_gc_r3_offset 44
10851533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
10951533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik
11051533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik/* Constants */
11151533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define regk_cris_no                              0x00000000
11251533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define regk_cris_rw_gc_cfg_default               0x00000000
11351533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#define regk_cris_yes                             0x00000001
11451533b615e605d86154ec1b4e585c8ca1b0b15b7Mikael Starvik#endif /* __cris_defs_asm_h */
115