Lines Matching defs:octeon_device

18 /*! \file octeon_device.h
115 * octeon_device structure
212 typedef int (*octeon_console_print_fn)(struct octeon_device *oct,
233 void (*setup_iq_regs)(struct octeon_device *, u32);
234 void (*setup_oq_regs)(struct octeon_device *, u32);
239 int (*setup_mbox)(struct octeon_device *);
240 int (*free_mbox)(struct octeon_device *);
242 int (*soft_reset)(struct octeon_device *);
243 int (*setup_device_regs)(struct octeon_device *);
244 void (*bar1_idx_setup)(struct octeon_device *, u64, u32, int);
245 void (*bar1_idx_write)(struct octeon_device *, u32, u32);
246 u32 (*bar1_idx_read)(struct octeon_device *, u32);
249 void (*enable_oq_pkt_time_intr)(struct octeon_device *, u32);
250 void (*disable_oq_pkt_time_intr)(struct octeon_device *, u32);
252 void (*enable_interrupt)(struct octeon_device *, u8);
253 void (*disable_interrupt)(struct octeon_device *, u8);
255 int (*enable_io_queues)(struct octeon_device *);
256 void (*disable_io_queues)(struct octeon_device *);
408 struct octeon_device *oct_dev;
423 struct octeon_device *oct;
430 struct octeon_device {
638 void octeon_free_device_mem(struct octeon_device *oct);
640 /* Look up a free entry in the octeon_device table and allocate resources
641 * for the octeon_device structure for an octeon device. Called at init
644 struct octeon_device *octeon_allocate_device(u32 pci_id,
655 int octeon_register_device(struct octeon_device *oct,
662 int octeon_deregister_device(struct octeon_device *oct);
669 int octeon_init_dispatch_list(struct octeon_device *octeon_dev);
675 void octeon_delete_dispatch_list(struct octeon_device *octeon_dev);
698 octeon_get_dispatch(struct octeon_device *octeon_dev, u16 opcode,
706 struct octeon_device *lio_get_device(u32 octeon_id);
725 u64 lio_pci_readq(struct octeon_device *oct, u64 addr);
737 void lio_pci_writeq(struct octeon_device *oct, u64 val, u64 addr);
758 int octeon_mem_access_ok(struct octeon_device *oct);
770 int octeon_wait_for_ddr_init(struct octeon_device *oct,
781 int octeon_wait_for_bootloader(struct octeon_device *oct,
790 int octeon_init_consoles(struct octeon_device *oct);
804 int octeon_add_console(struct octeon_device *oct, u32 console_num,
808 int octeon_console_write(struct octeon_device *oct, u32 console_num,
810 int octeon_console_write_avail(struct octeon_device *oct, u32 console_num);
812 int octeon_console_read_avail(struct octeon_device *oct, u32 console_num);
815 void octeon_remove_consoles(struct octeon_device *oct);
826 int octeon_console_send_cmd(struct octeon_device *oct, char *cmd_str,
839 int octeon_download_firmware(struct octeon_device *oct, const u8 *data,
849 int octeon_setup_instr_queues(struct octeon_device *oct);
856 int octeon_setup_output_queues(struct octeon_device *oct);
858 int octeon_get_tx_qsize(struct octeon_device *oct, u32 q_no);
860 int octeon_get_rx_qsize(struct octeon_device *oct, u32 q_no);
865 int octeon_set_io_queues_off(struct octeon_device *oct);
872 void octeon_set_droq_pkt_op(struct octeon_device *oct, u32 q_no, u32 enable);
880 void *oct_get_config_info(struct octeon_device *oct, u16 card_type);
885 struct octeon_config *octeon_get_conf(struct octeon_device *oct);
887 void octeon_free_ioq_vector(struct octeon_device *oct);
888 int octeon_allocate_ioq_vector(struct octeon_device *oct, u32 num_ioqs);
898 static inline u32 lio_get_priv_flag(struct octeon_device *octdev, u32 flag)
903 static inline void lio_set_priv_flag(struct octeon_device *octdev,