Blame view

drivers/rapidio/rio.h 2.93 KB
394b701ce   Matt Porter   [PATCH] RapidIO s...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  /*
   * RapidIO interconnect services
   *
   * Copyright 2005 MontaVista Software, Inc.
   * Matt Porter <mporter@kernel.crashing.org>
   *
   * This program is free software; you can redistribute  it and/or modify it
   * under  the terms of  the GNU General  Public License as published by the
   * Free Software Foundation;  either version 2 of the  License, or (at your
   * option) any later version.
   */
  
  #include <linux/device.h>
  #include <linux/list.h>
  #include <linux/rio.h>
6429cd49f   Alexandre Bounine   rapidio: add hand...
16
  #define RIO_MAX_CHK_RETRY	3
394b701ce   Matt Porter   [PATCH] RapidIO s...
17
18
19
20
  /* Functions internal to the RIO core code */
  
  extern u32 rio_mport_get_feature(struct rio_mport *mport, int local, u16 destid,
  				 u8 hopcount, int ftr);
e5cabeb3d   Alexandre Bounine   rapidio: add Port...
21
22
23
24
  extern u32 rio_mport_get_physefb(struct rio_mport *port, int local,
  				 u16 destid, u8 hopcount);
  extern u32 rio_mport_get_efb(struct rio_mport *port, int local, u16 destid,
  			     u8 hopcount, u32 from);
e274e0ed0   Alexandre Bounine   rapidio: add devi...
25
26
  extern int rio_mport_chk_dev_access(struct rio_mport *mport, u16 destid,
  				    u8 hopcount);
394b701ce   Matt Porter   [PATCH] RapidIO s...
27
28
29
  extern int rio_create_sysfs_dev_files(struct rio_dev *rdev);
  extern int rio_enum_mport(struct rio_mport *mport);
  extern int rio_disc_mport(struct rio_mport *mport);
07590ff03   Alexandre Bounine   rapidio: add IDT ...
30
31
32
33
34
35
36
37
  extern int rio_std_route_add_entry(struct rio_mport *mport, u16 destid,
  				   u8 hopcount, u16 table, u16 route_destid,
  				   u8 route_port);
  extern int rio_std_route_get_entry(struct rio_mport *mport, u16 destid,
  				   u8 hopcount, u16 table, u16 route_destid,
  				   u8 *route_port);
  extern int rio_std_route_clr_table(struct rio_mport *mport, u16 destid,
  				   u8 hopcount, u16 table);
e5cabeb3d   Alexandre Bounine   rapidio: add Port...
38
  extern int rio_set_port_lockout(struct rio_dev *rdev, u32 pnum, int lock);
af84ca38a   Alexandre Bounine   rapidio: add hand...
39
  extern struct rio_dev *rio_get_comptag(u32 comp_tag, struct rio_dev *from);
394b701ce   Matt Porter   [PATCH] RapidIO s...
40
41
42
43
  
  /* Structures internal to the RIO core code */
  extern struct device_attribute rio_dev_attrs[];
  extern spinlock_t rio_global_list_lock;
058f88d67   Alexandre Bounine   rapidio: modify i...
44
45
  extern struct rio_switch_ops __start_rio_switch_ops[];
  extern struct rio_switch_ops __end_rio_switch_ops[];
fa78cc517   Matt Porter   [PATCH] rapidio: ...
46

394b701ce   Matt Porter   [PATCH] RapidIO s...
47
  /* Helpers internal to the RIO core code */
058f88d67   Alexandre Bounine   rapidio: modify i...
48
49
50
  #define DECLARE_RIO_SWITCH_SECTION(section, name, vid, did, init_hook) \
  	static const struct rio_switch_ops __rio_switch_##name __used \
  	__section(section) = { vid, did, init_hook };
394b701ce   Matt Porter   [PATCH] RapidIO s...
51
52
  
  /**
058f88d67   Alexandre Bounine   rapidio: modify i...
53
   * DECLARE_RIO_SWITCH_INIT - Registers switch initialization routine
394b701ce   Matt Porter   [PATCH] RapidIO s...
54
55
   * @vid: RIO vendor ID
   * @did: RIO device ID
058f88d67   Alexandre Bounine   rapidio: modify i...
56
   * @init_hook: Callback that performs switch-specific initialization
394b701ce   Matt Porter   [PATCH] RapidIO s...
57
   *
058f88d67   Alexandre Bounine   rapidio: modify i...
58
59
60
61
62
   * Manipulating switch route tables and error management in RIO
   * is switch specific. This registers a switch by vendor and device ID with
   * initialization callback for setting up switch operations and (if required)
   * hardware initialization. A &struct rio_switch_ops is initialized with
   * pointer to the init routine and placed into a RIO-specific kernel section.
394b701ce   Matt Porter   [PATCH] RapidIO s...
63
   */
058f88d67   Alexandre Bounine   rapidio: modify i...
64
65
66
  #define DECLARE_RIO_SWITCH_INIT(vid, did, init_hook)		\
  	DECLARE_RIO_SWITCH_SECTION(.rio_switch_ops, vid##did, \
  			vid, did, init_hook)
394b701ce   Matt Porter   [PATCH] RapidIO s...
67

e04232360   Zhang Wei   [RAPIDIO] Auto-pr...
68
69
  #define RIO_GET_DID(size, x)	(size ? (x & 0xffff) : ((x & 0x00ff0000) >> 16))
  #define RIO_SET_DID(size, x)	(size ? (x & 0xffff) : ((x & 0x000000ff) << 16))