net: liquidio: fix mixed module-builtin object

With CONFIG_LIQUIDIO=m and CONFIG_LIQUIDIO_VF=y (or vice versa),
$(common-objs) are linked to a module and also to vmlinux even though
the expected CFLAGS are different between builtins and modules.

This is the same situation as fixed by commit 637a642f5ca5 ("zstd:
Fixing mixed module-builtin objects").

Introduce the new module, liquidio-core, to provide the common functions
to liquidio and liquidio-vf.

Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Reviewed-by: Simon Horman <simon.horman@corigine.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Masahiro Yamada 2023-06-07 02:18:49 +09:00 committed by David S. Miller
parent 0824a987a5
commit f71be9d084
14 changed files with 89 additions and 3 deletions

View File

@ -62,6 +62,9 @@ config CAVIUM_PTP
Precision Time Protocol or other purposes. Timestamps can be used in Precision Time Protocol or other purposes. Timestamps can be used in
BGX, TNS, GTI, and NIC blocks. BGX, TNS, GTI, and NIC blocks.
config LIQUIDIO_CORE
tristate
config LIQUIDIO config LIQUIDIO
tristate "Cavium LiquidIO support" tristate "Cavium LiquidIO support"
depends on 64BIT && PCI depends on 64BIT && PCI
@ -69,6 +72,7 @@ config LIQUIDIO
depends on PTP_1588_CLOCK_OPTIONAL depends on PTP_1588_CLOCK_OPTIONAL
select FW_LOADER select FW_LOADER
select LIBCRC32C select LIBCRC32C
select LIQUIDIO_CORE
select NET_DEVLINK select NET_DEVLINK
help help
This driver supports Cavium LiquidIO Intelligent Server Adapters This driver supports Cavium LiquidIO Intelligent Server Adapters
@ -92,6 +96,7 @@ config LIQUIDIO_VF
tristate "Cavium LiquidIO VF support" tristate "Cavium LiquidIO VF support"
depends on 64BIT && PCI_MSI depends on 64BIT && PCI_MSI
depends on PTP_1588_CLOCK_OPTIONAL depends on PTP_1588_CLOCK_OPTIONAL
select LIQUIDIO_CORE
help help
This driver supports Cavium LiquidIO Intelligent Server Adapter This driver supports Cavium LiquidIO Intelligent Server Adapter
based on CN23XX chips. based on CN23XX chips.

View File

@ -3,7 +3,9 @@
# Cavium Liquidio ethernet device driver # Cavium Liquidio ethernet device driver
# #
common-objs := lio_ethtool.o \ obj-$(CONFIG_LIQUIDIO_CORE) += liquidio-core.o
liquidio-core-y := \
lio_ethtool.o \
lio_core.o \ lio_core.o \
request_manager.o \ request_manager.o \
response_manager.o \ response_manager.o \
@ -18,7 +20,7 @@ common-objs := lio_ethtool.o \
octeon_nic.o octeon_nic.o
obj-$(CONFIG_LIQUIDIO) += liquidio.o obj-$(CONFIG_LIQUIDIO) += liquidio.o
liquidio-y := lio_main.o octeon_console.o lio_vf_rep.o $(common-objs) liquidio-y := lio_main.o octeon_console.o lio_vf_rep.o
obj-$(CONFIG_LIQUIDIO_VF) += liquidio_vf.o obj-$(CONFIG_LIQUIDIO_VF) += liquidio_vf.o
liquidio_vf-y := lio_vf_main.o $(common-objs) liquidio_vf-y := lio_vf_main.o

View File

@ -1375,6 +1375,7 @@ int setup_cn23xx_octeon_pf_device(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(setup_cn23xx_octeon_pf_device);
int validate_cn23xx_pf_config_info(struct octeon_device *oct, int validate_cn23xx_pf_config_info(struct octeon_device *oct,
struct octeon_config *conf23xx) struct octeon_config *conf23xx)
@ -1433,6 +1434,7 @@ int cn23xx_fw_loaded(struct octeon_device *oct)
val = octeon_read_csr64(oct, CN23XX_SLI_SCRATCH2); val = octeon_read_csr64(oct, CN23XX_SLI_SCRATCH2);
return (val >> SCR2_BIT_FW_LOADED) & 1ULL; return (val >> SCR2_BIT_FW_LOADED) & 1ULL;
} }
EXPORT_SYMBOL_GPL(cn23xx_fw_loaded);
void cn23xx_tell_vf_its_macaddr_changed(struct octeon_device *oct, int vfidx, void cn23xx_tell_vf_its_macaddr_changed(struct octeon_device *oct, int vfidx,
u8 *mac) u8 *mac)
@ -1454,6 +1456,7 @@ void cn23xx_tell_vf_its_macaddr_changed(struct octeon_device *oct, int vfidx,
octeon_mbox_write(oct, &mbox_cmd); octeon_mbox_write(oct, &mbox_cmd);
} }
} }
EXPORT_SYMBOL_GPL(cn23xx_tell_vf_its_macaddr_changed);
static void static void
cn23xx_get_vf_stats_callback(struct octeon_device *oct, cn23xx_get_vf_stats_callback(struct octeon_device *oct,
@ -1508,3 +1511,4 @@ int cn23xx_get_vf_stats(struct octeon_device *oct, int vfidx,
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(cn23xx_get_vf_stats);

View File

@ -384,6 +384,7 @@ void cn23xx_vf_ask_pf_to_do_flr(struct octeon_device *oct)
octeon_mbox_write(oct, &mbox_cmd); octeon_mbox_write(oct, &mbox_cmd);
} }
EXPORT_SYMBOL_GPL(cn23xx_vf_ask_pf_to_do_flr);
static void octeon_pfvf_hs_callback(struct octeon_device *oct, static void octeon_pfvf_hs_callback(struct octeon_device *oct,
struct octeon_mbox_cmd *cmd, struct octeon_mbox_cmd *cmd,
@ -466,6 +467,7 @@ int cn23xx_octeon_pfvf_handshake(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(cn23xx_octeon_pfvf_handshake);
static void cn23xx_handle_vf_mbox_intr(struct octeon_ioq_vector *ioq_vector) static void cn23xx_handle_vf_mbox_intr(struct octeon_ioq_vector *ioq_vector)
{ {
@ -678,3 +680,4 @@ int cn23xx_setup_octeon_vf_device(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(cn23xx_setup_octeon_vf_device);

View File

@ -697,6 +697,7 @@ int lio_setup_cn66xx_octeon_device(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(lio_setup_cn66xx_octeon_device);
int lio_validate_cn6xxx_config_info(struct octeon_device *oct, int lio_validate_cn6xxx_config_info(struct octeon_device *oct,
struct octeon_config *conf6xxx) struct octeon_config *conf6xxx)

View File

@ -181,3 +181,4 @@ int lio_setup_cn68xx_octeon_device(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(lio_setup_cn68xx_octeon_device);

View File

@ -26,6 +26,9 @@
#include "octeon_main.h" #include "octeon_main.h"
#include "octeon_network.h" #include "octeon_network.h"
MODULE_AUTHOR("Cavium Networks, <support@cavium.com>");
MODULE_LICENSE("GPL");
/* OOM task polling interval */ /* OOM task polling interval */
#define LIO_OOM_POLL_INTERVAL_MS 250 #define LIO_OOM_POLL_INTERVAL_MS 250
@ -71,6 +74,7 @@ void lio_delete_glists(struct lio *lio)
kfree(lio->glist); kfree(lio->glist);
lio->glist = NULL; lio->glist = NULL;
} }
EXPORT_SYMBOL_GPL(lio_delete_glists);
/** /**
* lio_setup_glists - Setup gather lists * lio_setup_glists - Setup gather lists
@ -154,6 +158,7 @@ int lio_setup_glists(struct octeon_device *oct, struct lio *lio, int num_iqs)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(lio_setup_glists);
int liquidio_set_feature(struct net_device *netdev, int cmd, u16 param1) int liquidio_set_feature(struct net_device *netdev, int cmd, u16 param1)
{ {
@ -180,6 +185,7 @@ int liquidio_set_feature(struct net_device *netdev, int cmd, u16 param1)
} }
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(liquidio_set_feature);
void octeon_report_tx_completion_to_bql(void *txq, unsigned int pkts_compl, void octeon_report_tx_completion_to_bql(void *txq, unsigned int pkts_compl,
unsigned int bytes_compl) unsigned int bytes_compl)
@ -395,6 +401,7 @@ void liquidio_link_ctrl_cmd_completion(void *nctrl_ptr)
nctrl->ncmd.s.cmd); nctrl->ncmd.s.cmd);
} }
} }
EXPORT_SYMBOL_GPL(liquidio_link_ctrl_cmd_completion);
void octeon_pf_changed_vf_macaddr(struct octeon_device *oct, u8 *mac) void octeon_pf_changed_vf_macaddr(struct octeon_device *oct, u8 *mac)
{ {
@ -478,6 +485,7 @@ int setup_rx_oom_poll_fn(struct net_device *netdev)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(setup_rx_oom_poll_fn);
void cleanup_rx_oom_poll_fn(struct net_device *netdev) void cleanup_rx_oom_poll_fn(struct net_device *netdev)
{ {
@ -495,6 +503,7 @@ void cleanup_rx_oom_poll_fn(struct net_device *netdev)
} }
} }
} }
EXPORT_SYMBOL_GPL(cleanup_rx_oom_poll_fn);
/* Runs in interrupt context. */ /* Runs in interrupt context. */
static void lio_update_txq_status(struct octeon_device *oct, int iq_num) static void lio_update_txq_status(struct octeon_device *oct, int iq_num)
@ -899,6 +908,7 @@ int liquidio_setup_io_queues(struct octeon_device *octeon_dev, int ifidx,
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(liquidio_setup_io_queues);
static static
int liquidio_schedule_msix_droq_pkt_handler(struct octeon_droq *droq, u64 ret) int liquidio_schedule_msix_droq_pkt_handler(struct octeon_droq *droq, u64 ret)
@ -1194,6 +1204,7 @@ int octeon_setup_interrupt(struct octeon_device *oct, u32 num_ioqs)
} }
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_setup_interrupt);
/** /**
* liquidio_change_mtu - Net device change_mtu * liquidio_change_mtu - Net device change_mtu
@ -1256,6 +1267,7 @@ int liquidio_change_mtu(struct net_device *netdev, int new_mtu)
WRITE_ONCE(sc->caller_is_done, true); WRITE_ONCE(sc->caller_is_done, true);
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(liquidio_change_mtu);
int lio_wait_for_clean_oq(struct octeon_device *oct) int lio_wait_for_clean_oq(struct octeon_device *oct)
{ {
@ -1279,6 +1291,7 @@ int lio_wait_for_clean_oq(struct octeon_device *oct)
return pending_pkts; return pending_pkts;
} }
EXPORT_SYMBOL_GPL(lio_wait_for_clean_oq);
static void static void
octnet_nic_stats_callback(struct octeon_device *oct_dev, octnet_nic_stats_callback(struct octeon_device *oct_dev,
@ -1509,6 +1522,7 @@ lio_fetch_stats_exit:
return; return;
} }
EXPORT_SYMBOL_GPL(lio_fetch_stats);
int liquidio_set_speed(struct lio *lio, int speed) int liquidio_set_speed(struct lio *lio, int speed)
{ {
@ -1659,6 +1673,7 @@ int liquidio_get_speed(struct lio *lio)
return retval; return retval;
} }
EXPORT_SYMBOL_GPL(liquidio_get_speed);
int liquidio_set_fec(struct lio *lio, int on_off) int liquidio_set_fec(struct lio *lio, int on_off)
{ {
@ -1812,3 +1827,4 @@ int liquidio_get_fec(struct lio *lio)
return retval; return retval;
} }
EXPORT_SYMBOL_GPL(liquidio_get_fec);

View File

@ -3180,3 +3180,4 @@ void liquidio_set_ethtool_ops(struct net_device *netdev)
else else
netdev->ethtool_ops = &lio_ethtool_ops; netdev->ethtool_ops = &lio_ethtool_ops;
} }
EXPORT_SYMBOL_GPL(liquidio_set_ethtool_ops);

View File

@ -564,6 +564,7 @@ void octeon_init_device_list(int conf_type)
for (i = 0; i < MAX_OCTEON_DEVICES; i++) for (i = 0; i < MAX_OCTEON_DEVICES; i++)
oct_set_config_info(i, conf_type); oct_set_config_info(i, conf_type);
} }
EXPORT_SYMBOL_GPL(octeon_init_device_list);
static void *__retrieve_octeon_config_info(struct octeon_device *oct, static void *__retrieve_octeon_config_info(struct octeon_device *oct,
u16 card_type) u16 card_type)
@ -633,6 +634,7 @@ char *lio_get_state_string(atomic_t *state_ptr)
return oct_dev_state_str[OCT_DEV_STATE_INVALID]; return oct_dev_state_str[OCT_DEV_STATE_INVALID];
return oct_dev_state_str[istate]; return oct_dev_state_str[istate];
} }
EXPORT_SYMBOL_GPL(lio_get_state_string);
static char *get_oct_app_string(u32 app_mode) static char *get_oct_app_string(u32 app_mode)
{ {
@ -661,6 +663,7 @@ void octeon_free_device_mem(struct octeon_device *oct)
octeon_device[i] = NULL; octeon_device[i] = NULL;
octeon_device_count--; octeon_device_count--;
} }
EXPORT_SYMBOL_GPL(octeon_free_device_mem);
static struct octeon_device *octeon_allocate_device_mem(u32 pci_id, static struct octeon_device *octeon_allocate_device_mem(u32 pci_id,
u32 priv_size) u32 priv_size)
@ -747,6 +750,7 @@ struct octeon_device *octeon_allocate_device(u32 pci_id,
return oct; return oct;
} }
EXPORT_SYMBOL_GPL(octeon_allocate_device);
/** Register a device's bus location at initialization time. /** Register a device's bus location at initialization time.
* @param octeon_dev - pointer to the octeon device structure. * @param octeon_dev - pointer to the octeon device structure.
@ -804,6 +808,7 @@ int octeon_register_device(struct octeon_device *oct,
return refcount; return refcount;
} }
EXPORT_SYMBOL_GPL(octeon_register_device);
/** Deregister a device at de-initialization time. /** Deregister a device at de-initialization time.
* @param octeon_dev - pointer to the octeon device structure. * @param octeon_dev - pointer to the octeon device structure.
@ -821,6 +826,7 @@ int octeon_deregister_device(struct octeon_device *oct)
return refcount; return refcount;
} }
EXPORT_SYMBOL_GPL(octeon_deregister_device);
int int
octeon_allocate_ioq_vector(struct octeon_device *oct, u32 num_ioqs) octeon_allocate_ioq_vector(struct octeon_device *oct, u32 num_ioqs)
@ -853,12 +859,14 @@ octeon_allocate_ioq_vector(struct octeon_device *oct, u32 num_ioqs)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_allocate_ioq_vector);
void void
octeon_free_ioq_vector(struct octeon_device *oct) octeon_free_ioq_vector(struct octeon_device *oct)
{ {
vfree(oct->ioq_vector); vfree(oct->ioq_vector);
} }
EXPORT_SYMBOL_GPL(octeon_free_ioq_vector);
/* this function is only for setting up the first queue */ /* this function is only for setting up the first queue */
int octeon_setup_instr_queues(struct octeon_device *oct) int octeon_setup_instr_queues(struct octeon_device *oct)
@ -904,6 +912,7 @@ int octeon_setup_instr_queues(struct octeon_device *oct)
oct->num_iqs++; oct->num_iqs++;
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_setup_instr_queues);
int octeon_setup_output_queues(struct octeon_device *oct) int octeon_setup_output_queues(struct octeon_device *oct)
{ {
@ -940,6 +949,7 @@ int octeon_setup_output_queues(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_setup_output_queues);
int octeon_set_io_queues_off(struct octeon_device *oct) int octeon_set_io_queues_off(struct octeon_device *oct)
{ {
@ -989,6 +999,7 @@ int octeon_set_io_queues_off(struct octeon_device *oct)
} }
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_set_io_queues_off);
void octeon_set_droq_pkt_op(struct octeon_device *oct, void octeon_set_droq_pkt_op(struct octeon_device *oct,
u32 q_no, u32 q_no,
@ -1027,6 +1038,7 @@ int octeon_init_dispatch_list(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_init_dispatch_list);
void octeon_delete_dispatch_list(struct octeon_device *oct) void octeon_delete_dispatch_list(struct octeon_device *oct)
{ {
@ -1058,6 +1070,7 @@ void octeon_delete_dispatch_list(struct octeon_device *oct)
kfree(temp); kfree(temp);
} }
} }
EXPORT_SYMBOL_GPL(octeon_delete_dispatch_list);
octeon_dispatch_fn_t octeon_dispatch_fn_t
octeon_get_dispatch(struct octeon_device *octeon_dev, u16 opcode, octeon_get_dispatch(struct octeon_device *octeon_dev, u16 opcode,
@ -1180,6 +1193,7 @@ octeon_register_dispatch_fn(struct octeon_device *oct,
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_register_dispatch_fn);
int octeon_core_drv_init(struct octeon_recv_info *recv_info, void *buf) int octeon_core_drv_init(struct octeon_recv_info *recv_info, void *buf)
{ {
@ -1262,6 +1276,7 @@ core_drv_init_err:
octeon_free_recv_info(recv_info); octeon_free_recv_info(recv_info);
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_core_drv_init);
int octeon_get_tx_qsize(struct octeon_device *oct, u32 q_no) int octeon_get_tx_qsize(struct octeon_device *oct, u32 q_no)
@ -1272,6 +1287,7 @@ int octeon_get_tx_qsize(struct octeon_device *oct, u32 q_no)
return -1; return -1;
} }
EXPORT_SYMBOL_GPL(octeon_get_tx_qsize);
int octeon_get_rx_qsize(struct octeon_device *oct, u32 q_no) int octeon_get_rx_qsize(struct octeon_device *oct, u32 q_no)
{ {
@ -1280,6 +1296,7 @@ int octeon_get_rx_qsize(struct octeon_device *oct, u32 q_no)
return oct->droq[q_no]->max_count; return oct->droq[q_no]->max_count;
return -1; return -1;
} }
EXPORT_SYMBOL_GPL(octeon_get_rx_qsize);
/* Retruns the host firmware handshake OCTEON specific configuration */ /* Retruns the host firmware handshake OCTEON specific configuration */
struct octeon_config *octeon_get_conf(struct octeon_device *oct) struct octeon_config *octeon_get_conf(struct octeon_device *oct)
@ -1302,6 +1319,7 @@ struct octeon_config *octeon_get_conf(struct octeon_device *oct)
} }
return default_oct_conf; return default_oct_conf;
} }
EXPORT_SYMBOL_GPL(octeon_get_conf);
/* scratch register address is same in all the OCT-II and CN70XX models */ /* scratch register address is same in all the OCT-II and CN70XX models */
#define CNXX_SLI_SCRATCH1 0x3C0 #define CNXX_SLI_SCRATCH1 0x3C0
@ -1318,6 +1336,7 @@ struct octeon_device *lio_get_device(u32 octeon_id)
else else
return octeon_device[octeon_id]; return octeon_device[octeon_id];
} }
EXPORT_SYMBOL_GPL(lio_get_device);
u64 lio_pci_readq(struct octeon_device *oct, u64 addr) u64 lio_pci_readq(struct octeon_device *oct, u64 addr)
{ {
@ -1349,6 +1368,7 @@ u64 lio_pci_readq(struct octeon_device *oct, u64 addr)
return val64; return val64;
} }
EXPORT_SYMBOL_GPL(lio_pci_readq);
void lio_pci_writeq(struct octeon_device *oct, void lio_pci_writeq(struct octeon_device *oct,
u64 val, u64 val,
@ -1369,6 +1389,7 @@ void lio_pci_writeq(struct octeon_device *oct,
spin_unlock_irqrestore(&oct->pci_win_lock, flags); spin_unlock_irqrestore(&oct->pci_win_lock, flags);
} }
EXPORT_SYMBOL_GPL(lio_pci_writeq);
int octeon_mem_access_ok(struct octeon_device *oct) int octeon_mem_access_ok(struct octeon_device *oct)
{ {
@ -1388,6 +1409,7 @@ int octeon_mem_access_ok(struct octeon_device *oct)
return access_okay ? 0 : 1; return access_okay ? 0 : 1;
} }
EXPORT_SYMBOL_GPL(octeon_mem_access_ok);
int octeon_wait_for_ddr_init(struct octeon_device *oct, u32 *timeout) int octeon_wait_for_ddr_init(struct octeon_device *oct, u32 *timeout)
{ {
@ -1408,6 +1430,7 @@ int octeon_wait_for_ddr_init(struct octeon_device *oct, u32 *timeout)
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(octeon_wait_for_ddr_init);
/* Get the octeon id assigned to the octeon device passed as argument. /* Get the octeon id assigned to the octeon device passed as argument.
* This function is exported to other modules. * This function is exported to other modules.
@ -1462,3 +1485,4 @@ void lio_enable_irq(struct octeon_droq *droq, struct octeon_instr_queue *iq)
} }
} }
} }
EXPORT_SYMBOL_GPL(lio_enable_irq);

View File

@ -107,6 +107,7 @@ u32 octeon_droq_check_hw_for_pkts(struct octeon_droq *droq)
return last_count; return last_count;
} }
EXPORT_SYMBOL_GPL(octeon_droq_check_hw_for_pkts);
static void octeon_droq_compute_max_packet_bufs(struct octeon_droq *droq) static void octeon_droq_compute_max_packet_bufs(struct octeon_droq *droq)
{ {
@ -216,6 +217,7 @@ int octeon_delete_droq(struct octeon_device *oct, u32 q_no)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_delete_droq);
int octeon_init_droq(struct octeon_device *oct, int octeon_init_droq(struct octeon_device *oct,
u32 q_no, u32 q_no,
@ -773,6 +775,7 @@ octeon_droq_process_packets(struct octeon_device *oct,
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_droq_process_packets);
/* /*
* Utility function to poll for packets. check_hw_for_packets must be * Utility function to poll for packets. check_hw_for_packets must be
@ -921,6 +924,7 @@ int octeon_unregister_droq_ops(struct octeon_device *oct, u32 q_no)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_unregister_droq_ops);
int octeon_create_droq(struct octeon_device *oct, int octeon_create_droq(struct octeon_device *oct,
u32 q_no, u32 num_descs, u32 q_no, u32 num_descs,

View File

@ -164,6 +164,7 @@ octeon_pci_read_core_mem(struct octeon_device *oct,
{ {
__octeon_pci_rw_core_mem(oct, coreaddr, buf, len, 1); __octeon_pci_rw_core_mem(oct, coreaddr, buf, len, 1);
} }
EXPORT_SYMBOL_GPL(octeon_pci_read_core_mem);
void void
octeon_pci_write_core_mem(struct octeon_device *oct, octeon_pci_write_core_mem(struct octeon_device *oct,
@ -173,6 +174,7 @@ octeon_pci_write_core_mem(struct octeon_device *oct,
{ {
__octeon_pci_rw_core_mem(oct, coreaddr, (u8 *)buf, len, 0); __octeon_pci_rw_core_mem(oct, coreaddr, (u8 *)buf, len, 0);
} }
EXPORT_SYMBOL_GPL(octeon_pci_write_core_mem);
u64 octeon_read_device_mem64(struct octeon_device *oct, u64 coreaddr) u64 octeon_read_device_mem64(struct octeon_device *oct, u64 coreaddr)
{ {
@ -182,6 +184,7 @@ u64 octeon_read_device_mem64(struct octeon_device *oct, u64 coreaddr)
return be64_to_cpu(ret); return be64_to_cpu(ret);
} }
EXPORT_SYMBOL_GPL(octeon_read_device_mem64);
u32 octeon_read_device_mem32(struct octeon_device *oct, u64 coreaddr) u32 octeon_read_device_mem32(struct octeon_device *oct, u64 coreaddr)
{ {
@ -191,6 +194,7 @@ u32 octeon_read_device_mem32(struct octeon_device *oct, u64 coreaddr)
return be32_to_cpu(ret); return be32_to_cpu(ret);
} }
EXPORT_SYMBOL_GPL(octeon_read_device_mem32);
void octeon_write_device_mem32(struct octeon_device *oct, u64 coreaddr, void octeon_write_device_mem32(struct octeon_device *oct, u64 coreaddr,
u32 val) u32 val)
@ -199,3 +203,4 @@ void octeon_write_device_mem32(struct octeon_device *oct, u64 coreaddr,
__octeon_pci_rw_core_mem(oct, coreaddr, (u8 *)&t, 4, 0); __octeon_pci_rw_core_mem(oct, coreaddr, (u8 *)&t, 4, 0);
} }
EXPORT_SYMBOL_GPL(octeon_write_device_mem32);

View File

@ -79,6 +79,7 @@ octeon_alloc_soft_command_resp(struct octeon_device *oct,
return sc; return sc;
} }
EXPORT_SYMBOL_GPL(octeon_alloc_soft_command_resp);
int octnet_send_nic_data_pkt(struct octeon_device *oct, int octnet_send_nic_data_pkt(struct octeon_device *oct,
struct octnic_data_pkt *ndata, struct octnic_data_pkt *ndata,
@ -90,6 +91,7 @@ int octnet_send_nic_data_pkt(struct octeon_device *oct,
ndata->buf, ndata->datasize, ndata->buf, ndata->datasize,
ndata->reqtype); ndata->reqtype);
} }
EXPORT_SYMBOL_GPL(octnet_send_nic_data_pkt);
static inline struct octeon_soft_command static inline struct octeon_soft_command
*octnic_alloc_ctrl_pkt_sc(struct octeon_device *oct, *octnic_alloc_ctrl_pkt_sc(struct octeon_device *oct,
@ -196,3 +198,4 @@ octnet_send_nic_ctrl_pkt(struct octeon_device *oct,
return retval; return retval;
} }
EXPORT_SYMBOL_GPL(octnet_send_nic_ctrl_pkt);

View File

@ -185,6 +185,7 @@ int octeon_delete_instr_queue(struct octeon_device *oct, u32 iq_no)
} }
return 1; return 1;
} }
EXPORT_SYMBOL_GPL(octeon_delete_instr_queue);
/* Return 0 on success, 1 on failure */ /* Return 0 on success, 1 on failure */
int octeon_setup_iq(struct octeon_device *oct, int octeon_setup_iq(struct octeon_device *oct,
@ -258,6 +259,7 @@ int lio_wait_for_instr_fetch(struct octeon_device *oct)
return instr_cnt; return instr_cnt;
} }
EXPORT_SYMBOL_GPL(lio_wait_for_instr_fetch);
static inline void static inline void
ring_doorbell(struct octeon_device *oct, struct octeon_instr_queue *iq) ring_doorbell(struct octeon_device *oct, struct octeon_instr_queue *iq)
@ -282,6 +284,7 @@ octeon_ring_doorbell_locked(struct octeon_device *oct, u32 iq_no)
ring_doorbell(oct, iq); ring_doorbell(oct, iq);
spin_unlock(&iq->post_lock); spin_unlock(&iq->post_lock);
} }
EXPORT_SYMBOL_GPL(octeon_ring_doorbell_locked);
static inline void __copy_cmd_into_iq(struct octeon_instr_queue *iq, static inline void __copy_cmd_into_iq(struct octeon_instr_queue *iq,
u8 *cmd) u8 *cmd)
@ -345,6 +348,7 @@ octeon_register_reqtype_free_fn(struct octeon_device *oct, int reqtype,
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_register_reqtype_free_fn);
static inline void static inline void
__add_to_request_list(struct octeon_instr_queue *iq, __add_to_request_list(struct octeon_instr_queue *iq,
@ -430,6 +434,7 @@ lio_process_iq_request_list(struct octeon_device *oct,
return inst_count; return inst_count;
} }
EXPORT_SYMBOL_GPL(lio_process_iq_request_list);
/* Can only be called from process context */ /* Can only be called from process context */
int int
@ -566,6 +571,7 @@ octeon_send_command(struct octeon_device *oct, u32 iq_no,
return st.status; return st.status;
} }
EXPORT_SYMBOL_GPL(octeon_send_command);
void void
octeon_prepare_soft_command(struct octeon_device *oct, octeon_prepare_soft_command(struct octeon_device *oct,
@ -673,6 +679,7 @@ octeon_prepare_soft_command(struct octeon_device *oct,
} }
} }
} }
EXPORT_SYMBOL_GPL(octeon_prepare_soft_command);
int octeon_send_soft_command(struct octeon_device *oct, int octeon_send_soft_command(struct octeon_device *oct,
struct octeon_soft_command *sc) struct octeon_soft_command *sc)
@ -726,6 +733,7 @@ int octeon_send_soft_command(struct octeon_device *oct,
return (octeon_send_command(oct, sc->iq_no, 1, &sc->cmd, sc, return (octeon_send_command(oct, sc->iq_no, 1, &sc->cmd, sc,
len, REQTYPE_SOFT_COMMAND)); len, REQTYPE_SOFT_COMMAND));
} }
EXPORT_SYMBOL_GPL(octeon_send_soft_command);
int octeon_setup_sc_buffer_pool(struct octeon_device *oct) int octeon_setup_sc_buffer_pool(struct octeon_device *oct)
{ {
@ -755,6 +763,7 @@ int octeon_setup_sc_buffer_pool(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_setup_sc_buffer_pool);
int octeon_free_sc_done_list(struct octeon_device *oct) int octeon_free_sc_done_list(struct octeon_device *oct)
{ {
@ -794,6 +803,7 @@ int octeon_free_sc_done_list(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_free_sc_done_list);
int octeon_free_sc_zombie_list(struct octeon_device *oct) int octeon_free_sc_zombie_list(struct octeon_device *oct)
{ {
@ -818,6 +828,7 @@ int octeon_free_sc_zombie_list(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_free_sc_zombie_list);
int octeon_free_sc_buffer_pool(struct octeon_device *oct) int octeon_free_sc_buffer_pool(struct octeon_device *oct)
{ {
@ -842,6 +853,7 @@ int octeon_free_sc_buffer_pool(struct octeon_device *oct)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(octeon_free_sc_buffer_pool);
struct octeon_soft_command *octeon_alloc_soft_command(struct octeon_device *oct, struct octeon_soft_command *octeon_alloc_soft_command(struct octeon_device *oct,
u32 datasize, u32 datasize,
@ -913,6 +925,7 @@ struct octeon_soft_command *octeon_alloc_soft_command(struct octeon_device *oct,
return sc; return sc;
} }
EXPORT_SYMBOL_GPL(octeon_alloc_soft_command);
void octeon_free_soft_command(struct octeon_device *oct, void octeon_free_soft_command(struct octeon_device *oct,
struct octeon_soft_command *sc) struct octeon_soft_command *sc)
@ -925,3 +938,4 @@ void octeon_free_soft_command(struct octeon_device *oct,
spin_unlock_bh(&oct->sc_buf_pool.lock); spin_unlock_bh(&oct->sc_buf_pool.lock);
} }
EXPORT_SYMBOL_GPL(octeon_free_soft_command);

View File

@ -52,12 +52,14 @@ int octeon_setup_response_list(struct octeon_device *oct)
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(octeon_setup_response_list);
void octeon_delete_response_list(struct octeon_device *oct) void octeon_delete_response_list(struct octeon_device *oct)
{ {
cancel_delayed_work_sync(&oct->dma_comp_wq.wk.work); cancel_delayed_work_sync(&oct->dma_comp_wq.wk.work);
destroy_workqueue(oct->dma_comp_wq.wq); destroy_workqueue(oct->dma_comp_wq.wq);
} }
EXPORT_SYMBOL_GPL(octeon_delete_response_list);
int lio_process_ordered_list(struct octeon_device *octeon_dev, int lio_process_ordered_list(struct octeon_device *octeon_dev,
u32 force_quit) u32 force_quit)
@ -219,6 +221,7 @@ int lio_process_ordered_list(struct octeon_device *octeon_dev,
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(lio_process_ordered_list);
static void oct_poll_req_completion(struct work_struct *work) static void oct_poll_req_completion(struct work_struct *work)
{ {