mc.h (20619B)
1/* SPDX-License-Identifier: GPL-2.0 */ 2/* 3 * Freescale Management Complex (MC) bus public interface 4 * 5 * Copyright (C) 2014-2016 Freescale Semiconductor, Inc. 6 * Copyright 2019-2020 NXP 7 * Author: German Rivera <German.Rivera@freescale.com> 8 * 9 */ 10#ifndef _FSL_MC_H_ 11#define _FSL_MC_H_ 12 13#include <linux/device.h> 14#include <linux/mod_devicetable.h> 15#include <linux/interrupt.h> 16#include <uapi/linux/fsl_mc.h> 17 18#define FSL_MC_VENDOR_FREESCALE 0x1957 19 20struct irq_domain; 21struct msi_domain_info; 22 23struct fsl_mc_device; 24struct fsl_mc_io; 25 26/** 27 * struct fsl_mc_driver - MC object device driver object 28 * @driver: Generic device driver 29 * @match_id_table: table of supported device matching Ids 30 * @probe: Function called when a device is added 31 * @remove: Function called when a device is removed 32 * @shutdown: Function called at shutdown time to quiesce the device 33 * @suspend: Function called when a device is stopped 34 * @resume: Function called when a device is resumed 35 * @driver_managed_dma: Device driver doesn't use kernel DMA API for DMA. 36 * For most device drivers, no need to care about this flag 37 * as long as all DMAs are handled through the kernel DMA API. 38 * For some special ones, for example VFIO drivers, they know 39 * how to manage the DMA themselves and set this flag so that 40 * the IOMMU layer will allow them to setup and manage their 41 * own I/O address space. 42 * 43 * Generic DPAA device driver object for device drivers that are registered 44 * with a DPRC bus. This structure is to be embedded in each device-specific 45 * driver structure. 46 */ 47struct fsl_mc_driver { 48 struct device_driver driver; 49 const struct fsl_mc_device_id *match_id_table; 50 int (*probe)(struct fsl_mc_device *dev); 51 int (*remove)(struct fsl_mc_device *dev); 52 void (*shutdown)(struct fsl_mc_device *dev); 53 int (*suspend)(struct fsl_mc_device *dev, pm_message_t state); 54 int (*resume)(struct fsl_mc_device *dev); 55 bool driver_managed_dma; 56}; 57 58#define to_fsl_mc_driver(_drv) \ 59 container_of(_drv, struct fsl_mc_driver, driver) 60 61/** 62 * enum fsl_mc_pool_type - Types of allocatable MC bus resources 63 * 64 * Entries in these enum are used as indices in the array of resource 65 * pools of an fsl_mc_bus object. 66 */ 67enum fsl_mc_pool_type { 68 FSL_MC_POOL_DPMCP = 0x0, /* corresponds to "dpmcp" in the MC */ 69 FSL_MC_POOL_DPBP, /* corresponds to "dpbp" in the MC */ 70 FSL_MC_POOL_DPCON, /* corresponds to "dpcon" in the MC */ 71 FSL_MC_POOL_IRQ, 72 73 /* 74 * NOTE: New resource pool types must be added before this entry 75 */ 76 FSL_MC_NUM_POOL_TYPES 77}; 78 79/** 80 * struct fsl_mc_resource - MC generic resource 81 * @type: type of resource 82 * @id: unique MC resource Id within the resources of the same type 83 * @data: pointer to resource-specific data if the resource is currently 84 * allocated, or NULL if the resource is not currently allocated. 85 * @parent_pool: pointer to the parent resource pool from which this 86 * resource is allocated from. 87 * @node: Node in the free list of the corresponding resource pool 88 * 89 * NOTE: This structure is to be embedded as a field of specific 90 * MC resource structures. 91 */ 92struct fsl_mc_resource { 93 enum fsl_mc_pool_type type; 94 s32 id; 95 void *data; 96 struct fsl_mc_resource_pool *parent_pool; 97 struct list_head node; 98}; 99 100/** 101 * struct fsl_mc_device_irq - MC object device message-based interrupt 102 * @virq: Linux virtual interrupt number 103 * @mc_dev: MC object device that owns this interrupt 104 * @dev_irq_index: device-relative IRQ index 105 * @resource: MC generic resource associated with the interrupt 106 */ 107struct fsl_mc_device_irq { 108 unsigned int virq; 109 struct fsl_mc_device *mc_dev; 110 u8 dev_irq_index; 111 struct fsl_mc_resource resource; 112}; 113 114#define to_fsl_mc_irq(_mc_resource) \ 115 container_of(_mc_resource, struct fsl_mc_device_irq, resource) 116 117/* Opened state - Indicates that an object is open by at least one owner */ 118#define FSL_MC_OBJ_STATE_OPEN 0x00000001 119/* Plugged state - Indicates that the object is plugged */ 120#define FSL_MC_OBJ_STATE_PLUGGED 0x00000002 121 122/** 123 * Shareability flag - Object flag indicating no memory shareability. 124 * the object generates memory accesses that are non coherent with other 125 * masters; 126 * user is responsible for proper memory handling through IOMMU configuration. 127 */ 128#define FSL_MC_OBJ_FLAG_NO_MEM_SHAREABILITY 0x0001 129 130/** 131 * struct fsl_mc_obj_desc - Object descriptor 132 * @type: Type of object: NULL terminated string 133 * @id: ID of logical object resource 134 * @vendor: Object vendor identifier 135 * @ver_major: Major version number 136 * @ver_minor: Minor version number 137 * @irq_count: Number of interrupts supported by the object 138 * @region_count: Number of mappable regions supported by the object 139 * @state: Object state: combination of FSL_MC_OBJ_STATE_ states 140 * @label: Object label: NULL terminated string 141 * @flags: Object's flags 142 */ 143struct fsl_mc_obj_desc { 144 char type[16]; 145 int id; 146 u16 vendor; 147 u16 ver_major; 148 u16 ver_minor; 149 u8 irq_count; 150 u8 region_count; 151 u32 state; 152 char label[16]; 153 u16 flags; 154}; 155 156/** 157 * Bit masks for a MC object device (struct fsl_mc_device) flags 158 */ 159#define FSL_MC_IS_DPRC 0x0001 160 161/* Region flags */ 162/* Indicates that region can be mapped as cacheable */ 163#define FSL_MC_REGION_CACHEABLE 0x00000001 164 165/* Indicates that region can be mapped as shareable */ 166#define FSL_MC_REGION_SHAREABLE 0x00000002 167 168/** 169 * struct fsl_mc_device - MC object device object 170 * @dev: Linux driver model device object 171 * @dma_mask: Default DMA mask 172 * @flags: MC object device flags 173 * @icid: Isolation context ID for the device 174 * @mc_handle: MC handle for the corresponding MC object opened 175 * @mc_io: Pointer to MC IO object assigned to this device or 176 * NULL if none. 177 * @obj_desc: MC description of the DPAA device 178 * @regions: pointer to array of MMIO region entries 179 * @irqs: pointer to array of pointers to interrupts allocated to this device 180 * @resource: generic resource associated with this MC object device, if any. 181 * @driver_override: driver name to force a match; do not set directly, 182 * because core frees it; use driver_set_override() to 183 * set or clear it. 184 * 185 * Generic device object for MC object devices that are "attached" to a 186 * MC bus. 187 * 188 * NOTES: 189 * - For a non-DPRC object its icid is the same as its parent DPRC's icid. 190 * - The SMMU notifier callback gets invoked after device_add() has been 191 * called for an MC object device, but before the device-specific probe 192 * callback gets called. 193 * - DP_OBJ_DPRC objects are the only MC objects that have built-in MC 194 * portals. For all other MC objects, their device drivers are responsible for 195 * allocating MC portals for them by calling fsl_mc_portal_allocate(). 196 * - Some types of MC objects (e.g., DP_OBJ_DPBP, DP_OBJ_DPCON) are 197 * treated as resources that can be allocated/deallocated from the 198 * corresponding resource pool in the object's parent DPRC, using the 199 * fsl_mc_object_allocate()/fsl_mc_object_free() functions. These MC objects 200 * are known as "allocatable" objects. For them, the corresponding 201 * fsl_mc_device's 'resource' points to the associated resource object. 202 * For MC objects that are not allocatable (e.g., DP_OBJ_DPRC, DP_OBJ_DPNI), 203 * 'resource' is NULL. 204 */ 205struct fsl_mc_device { 206 struct device dev; 207 u64 dma_mask; 208 u16 flags; 209 u32 icid; 210 u16 mc_handle; 211 struct fsl_mc_io *mc_io; 212 struct fsl_mc_obj_desc obj_desc; 213 struct resource *regions; 214 struct fsl_mc_device_irq **irqs; 215 struct fsl_mc_resource *resource; 216 struct device_link *consumer_link; 217 const char *driver_override; 218}; 219 220#define to_fsl_mc_device(_dev) \ 221 container_of(_dev, struct fsl_mc_device, dev) 222 223struct mc_cmd_header { 224 u8 src_id; 225 u8 flags_hw; 226 u8 status; 227 u8 flags_sw; 228 __le16 token; 229 __le16 cmd_id; 230}; 231 232enum mc_cmd_status { 233 MC_CMD_STATUS_OK = 0x0, /* Completed successfully */ 234 MC_CMD_STATUS_READY = 0x1, /* Ready to be processed */ 235 MC_CMD_STATUS_AUTH_ERR = 0x3, /* Authentication error */ 236 MC_CMD_STATUS_NO_PRIVILEGE = 0x4, /* No privilege */ 237 MC_CMD_STATUS_DMA_ERR = 0x5, /* DMA or I/O error */ 238 MC_CMD_STATUS_CONFIG_ERR = 0x6, /* Configuration error */ 239 MC_CMD_STATUS_TIMEOUT = 0x7, /* Operation timed out */ 240 MC_CMD_STATUS_NO_RESOURCE = 0x8, /* No resources */ 241 MC_CMD_STATUS_NO_MEMORY = 0x9, /* No memory available */ 242 MC_CMD_STATUS_BUSY = 0xA, /* Device is busy */ 243 MC_CMD_STATUS_UNSUPPORTED_OP = 0xB, /* Unsupported operation */ 244 MC_CMD_STATUS_INVALID_STATE = 0xC /* Invalid state */ 245}; 246 247/* 248 * MC command flags 249 */ 250 251/* High priority flag */ 252#define MC_CMD_FLAG_PRI 0x80 253/* Command completion flag */ 254#define MC_CMD_FLAG_INTR_DIS 0x01 255 256static inline __le64 mc_encode_cmd_header(u16 cmd_id, 257 u32 cmd_flags, 258 u16 token) 259{ 260 __le64 header = 0; 261 struct mc_cmd_header *hdr = (struct mc_cmd_header *)&header; 262 263 hdr->cmd_id = cpu_to_le16(cmd_id); 264 hdr->token = cpu_to_le16(token); 265 hdr->status = MC_CMD_STATUS_READY; 266 if (cmd_flags & MC_CMD_FLAG_PRI) 267 hdr->flags_hw = MC_CMD_FLAG_PRI; 268 if (cmd_flags & MC_CMD_FLAG_INTR_DIS) 269 hdr->flags_sw = MC_CMD_FLAG_INTR_DIS; 270 271 return header; 272} 273 274static inline u16 mc_cmd_hdr_read_token(struct fsl_mc_command *cmd) 275{ 276 struct mc_cmd_header *hdr = (struct mc_cmd_header *)&cmd->header; 277 u16 token = le16_to_cpu(hdr->token); 278 279 return token; 280} 281 282struct mc_rsp_create { 283 __le32 object_id; 284}; 285 286struct mc_rsp_api_ver { 287 __le16 major_ver; 288 __le16 minor_ver; 289}; 290 291static inline u32 mc_cmd_read_object_id(struct fsl_mc_command *cmd) 292{ 293 struct mc_rsp_create *rsp_params; 294 295 rsp_params = (struct mc_rsp_create *)cmd->params; 296 return le32_to_cpu(rsp_params->object_id); 297} 298 299static inline void mc_cmd_read_api_version(struct fsl_mc_command *cmd, 300 u16 *major_ver, 301 u16 *minor_ver) 302{ 303 struct mc_rsp_api_ver *rsp_params; 304 305 rsp_params = (struct mc_rsp_api_ver *)cmd->params; 306 *major_ver = le16_to_cpu(rsp_params->major_ver); 307 *minor_ver = le16_to_cpu(rsp_params->minor_ver); 308} 309 310/** 311 * Bit masks for a MC I/O object (struct fsl_mc_io) flags 312 */ 313#define FSL_MC_IO_ATOMIC_CONTEXT_PORTAL 0x0001 314 315/** 316 * struct fsl_mc_io - MC I/O object to be passed-in to mc_send_command() 317 * @dev: device associated with this Mc I/O object 318 * @flags: flags for mc_send_command() 319 * @portal_size: MC command portal size in bytes 320 * @portal_phys_addr: MC command portal physical address 321 * @portal_virt_addr: MC command portal virtual address 322 * @dpmcp_dev: pointer to the DPMCP device associated with the MC portal. 323 * 324 * Fields are only meaningful if the FSL_MC_IO_ATOMIC_CONTEXT_PORTAL flag is not 325 * set: 326 * @mutex: Mutex to serialize mc_send_command() calls that use the same MC 327 * portal, if the fsl_mc_io object was created with the 328 * FSL_MC_IO_ATOMIC_CONTEXT_PORTAL flag off. mc_send_command() calls for this 329 * fsl_mc_io object must be made only from non-atomic context. 330 * 331 * Fields are only meaningful if the FSL_MC_IO_ATOMIC_CONTEXT_PORTAL flag is 332 * set: 333 * @spinlock: Spinlock to serialize mc_send_command() calls that use the same MC 334 * portal, if the fsl_mc_io object was created with the 335 * FSL_MC_IO_ATOMIC_CONTEXT_PORTAL flag on. mc_send_command() calls for this 336 * fsl_mc_io object can be made from atomic or non-atomic context. 337 */ 338struct fsl_mc_io { 339 struct device *dev; 340 u16 flags; 341 u32 portal_size; 342 phys_addr_t portal_phys_addr; 343 void __iomem *portal_virt_addr; 344 struct fsl_mc_device *dpmcp_dev; 345 union { 346 /* 347 * This field is only meaningful if the 348 * FSL_MC_IO_ATOMIC_CONTEXT_PORTAL flag is not set 349 */ 350 struct mutex mutex; /* serializes mc_send_command() */ 351 352 /* 353 * This field is only meaningful if the 354 * FSL_MC_IO_ATOMIC_CONTEXT_PORTAL flag is set 355 */ 356 raw_spinlock_t spinlock; /* serializes mc_send_command() */ 357 }; 358}; 359 360int mc_send_command(struct fsl_mc_io *mc_io, struct fsl_mc_command *cmd); 361 362#ifdef CONFIG_FSL_MC_BUS 363#define dev_is_fsl_mc(_dev) ((_dev)->bus == &fsl_mc_bus_type) 364#else 365/* If fsl-mc bus is not present device cannot belong to fsl-mc bus */ 366#define dev_is_fsl_mc(_dev) (0) 367#endif 368 369/* Macro to check if a device is a container device */ 370#define fsl_mc_is_cont_dev(_dev) (to_fsl_mc_device(_dev)->flags & \ 371 FSL_MC_IS_DPRC) 372 373/* Macro to get the container device of a MC device */ 374#define fsl_mc_cont_dev(_dev) (fsl_mc_is_cont_dev(_dev) ? \ 375 (_dev) : (_dev)->parent) 376 377/* 378 * module_fsl_mc_driver() - Helper macro for drivers that don't do 379 * anything special in module init/exit. This eliminates a lot of 380 * boilerplate. Each module may only use this macro once, and 381 * calling it replaces module_init() and module_exit() 382 */ 383#define module_fsl_mc_driver(__fsl_mc_driver) \ 384 module_driver(__fsl_mc_driver, fsl_mc_driver_register, \ 385 fsl_mc_driver_unregister) 386 387/* 388 * Macro to avoid include chaining to get THIS_MODULE 389 */ 390#define fsl_mc_driver_register(drv) \ 391 __fsl_mc_driver_register(drv, THIS_MODULE) 392 393int __must_check __fsl_mc_driver_register(struct fsl_mc_driver *fsl_mc_driver, 394 struct module *owner); 395 396void fsl_mc_driver_unregister(struct fsl_mc_driver *driver); 397 398/** 399 * struct fsl_mc_version 400 * @major: Major version number: incremented on API compatibility changes 401 * @minor: Minor version number: incremented on API additions (that are 402 * backward compatible); reset when major version is incremented 403 * @revision: Internal revision number: incremented on implementation changes 404 * and/or bug fixes that have no impact on API 405 */ 406struct fsl_mc_version { 407 u32 major; 408 u32 minor; 409 u32 revision; 410}; 411 412struct fsl_mc_version *fsl_mc_get_version(void); 413 414int __must_check fsl_mc_portal_allocate(struct fsl_mc_device *mc_dev, 415 u16 mc_io_flags, 416 struct fsl_mc_io **new_mc_io); 417 418void fsl_mc_portal_free(struct fsl_mc_io *mc_io); 419 420int fsl_mc_portal_reset(struct fsl_mc_io *mc_io); 421 422int __must_check fsl_mc_object_allocate(struct fsl_mc_device *mc_dev, 423 enum fsl_mc_pool_type pool_type, 424 struct fsl_mc_device **new_mc_adev); 425 426void fsl_mc_object_free(struct fsl_mc_device *mc_adev); 427 428struct irq_domain *fsl_mc_msi_create_irq_domain(struct fwnode_handle *fwnode, 429 struct msi_domain_info *info, 430 struct irq_domain *parent); 431 432int __must_check fsl_mc_allocate_irqs(struct fsl_mc_device *mc_dev); 433 434void fsl_mc_free_irqs(struct fsl_mc_device *mc_dev); 435 436struct fsl_mc_device *fsl_mc_get_endpoint(struct fsl_mc_device *mc_dev, 437 u16 if_id); 438 439extern struct bus_type fsl_mc_bus_type; 440 441extern struct device_type fsl_mc_bus_dprc_type; 442extern struct device_type fsl_mc_bus_dpni_type; 443extern struct device_type fsl_mc_bus_dpio_type; 444extern struct device_type fsl_mc_bus_dpsw_type; 445extern struct device_type fsl_mc_bus_dpbp_type; 446extern struct device_type fsl_mc_bus_dpcon_type; 447extern struct device_type fsl_mc_bus_dpmcp_type; 448extern struct device_type fsl_mc_bus_dpmac_type; 449extern struct device_type fsl_mc_bus_dprtc_type; 450extern struct device_type fsl_mc_bus_dpseci_type; 451extern struct device_type fsl_mc_bus_dpdmux_type; 452extern struct device_type fsl_mc_bus_dpdcei_type; 453extern struct device_type fsl_mc_bus_dpaiop_type; 454extern struct device_type fsl_mc_bus_dpci_type; 455extern struct device_type fsl_mc_bus_dpdmai_type; 456 457static inline bool is_fsl_mc_bus_dprc(const struct fsl_mc_device *mc_dev) 458{ 459 return mc_dev->dev.type == &fsl_mc_bus_dprc_type; 460} 461 462static inline bool is_fsl_mc_bus_dpni(const struct fsl_mc_device *mc_dev) 463{ 464 return mc_dev->dev.type == &fsl_mc_bus_dpni_type; 465} 466 467static inline bool is_fsl_mc_bus_dpio(const struct fsl_mc_device *mc_dev) 468{ 469 return mc_dev->dev.type == &fsl_mc_bus_dpio_type; 470} 471 472static inline bool is_fsl_mc_bus_dpsw(const struct fsl_mc_device *mc_dev) 473{ 474 return mc_dev->dev.type == &fsl_mc_bus_dpsw_type; 475} 476 477static inline bool is_fsl_mc_bus_dpdmux(const struct fsl_mc_device *mc_dev) 478{ 479 return mc_dev->dev.type == &fsl_mc_bus_dpdmux_type; 480} 481 482static inline bool is_fsl_mc_bus_dpbp(const struct fsl_mc_device *mc_dev) 483{ 484 return mc_dev->dev.type == &fsl_mc_bus_dpbp_type; 485} 486 487static inline bool is_fsl_mc_bus_dpcon(const struct fsl_mc_device *mc_dev) 488{ 489 return mc_dev->dev.type == &fsl_mc_bus_dpcon_type; 490} 491 492static inline bool is_fsl_mc_bus_dpmcp(const struct fsl_mc_device *mc_dev) 493{ 494 return mc_dev->dev.type == &fsl_mc_bus_dpmcp_type; 495} 496 497static inline bool is_fsl_mc_bus_dpmac(const struct fsl_mc_device *mc_dev) 498{ 499 return mc_dev->dev.type == &fsl_mc_bus_dpmac_type; 500} 501 502static inline bool is_fsl_mc_bus_dprtc(const struct fsl_mc_device *mc_dev) 503{ 504 return mc_dev->dev.type == &fsl_mc_bus_dprtc_type; 505} 506 507static inline bool is_fsl_mc_bus_dpseci(const struct fsl_mc_device *mc_dev) 508{ 509 return mc_dev->dev.type == &fsl_mc_bus_dpseci_type; 510} 511 512static inline bool is_fsl_mc_bus_dpdcei(const struct fsl_mc_device *mc_dev) 513{ 514 return mc_dev->dev.type == &fsl_mc_bus_dpdcei_type; 515} 516 517static inline bool is_fsl_mc_bus_dpaiop(const struct fsl_mc_device *mc_dev) 518{ 519 return mc_dev->dev.type == &fsl_mc_bus_dpaiop_type; 520} 521 522static inline bool is_fsl_mc_bus_dpci(const struct fsl_mc_device *mc_dev) 523{ 524 return mc_dev->dev.type == &fsl_mc_bus_dpci_type; 525} 526 527static inline bool is_fsl_mc_bus_dpdmai(const struct fsl_mc_device *mc_dev) 528{ 529 return mc_dev->dev.type == &fsl_mc_bus_dpdmai_type; 530} 531 532#define DPRC_RESET_OPTION_NON_RECURSIVE 0x00000001 533int dprc_reset_container(struct fsl_mc_io *mc_io, 534 u32 cmd_flags, 535 u16 token, 536 int child_container_id, 537 u32 options); 538 539int dprc_scan_container(struct fsl_mc_device *mc_bus_dev, 540 bool alloc_interrupts); 541 542void dprc_remove_devices(struct fsl_mc_device *mc_bus_dev, 543 struct fsl_mc_obj_desc *obj_desc_array, 544 int num_child_objects_in_mc); 545 546int dprc_cleanup(struct fsl_mc_device *mc_dev); 547 548int dprc_setup(struct fsl_mc_device *mc_dev); 549 550/** 551 * Maximum number of total IRQs that can be pre-allocated for an MC bus' 552 * IRQ pool 553 */ 554#define FSL_MC_IRQ_POOL_MAX_TOTAL_IRQS 256 555 556int fsl_mc_populate_irq_pool(struct fsl_mc_device *mc_bus_dev, 557 unsigned int irq_count); 558 559void fsl_mc_cleanup_irq_pool(struct fsl_mc_device *mc_bus_dev); 560 561/* 562 * Data Path Buffer Pool (DPBP) API 563 * Contains initialization APIs and runtime control APIs for DPBP 564 */ 565 566int dpbp_open(struct fsl_mc_io *mc_io, 567 u32 cmd_flags, 568 int dpbp_id, 569 u16 *token); 570 571int dpbp_close(struct fsl_mc_io *mc_io, 572 u32 cmd_flags, 573 u16 token); 574 575int dpbp_enable(struct fsl_mc_io *mc_io, 576 u32 cmd_flags, 577 u16 token); 578 579int dpbp_disable(struct fsl_mc_io *mc_io, 580 u32 cmd_flags, 581 u16 token); 582 583int dpbp_reset(struct fsl_mc_io *mc_io, 584 u32 cmd_flags, 585 u16 token); 586 587/** 588 * struct dpbp_attr - Structure representing DPBP attributes 589 * @id: DPBP object ID 590 * @bpid: Hardware buffer pool ID; should be used as an argument in 591 * acquire/release operations on buffers 592 */ 593struct dpbp_attr { 594 int id; 595 u16 bpid; 596}; 597 598int dpbp_get_attributes(struct fsl_mc_io *mc_io, 599 u32 cmd_flags, 600 u16 token, 601 struct dpbp_attr *attr); 602 603/* Data Path Concentrator (DPCON) API 604 * Contains initialization APIs and runtime control APIs for DPCON 605 */ 606 607/** 608 * Use it to disable notifications; see dpcon_set_notification() 609 */ 610#define DPCON_INVALID_DPIO_ID (int)(-1) 611 612int dpcon_open(struct fsl_mc_io *mc_io, 613 u32 cmd_flags, 614 int dpcon_id, 615 u16 *token); 616 617int dpcon_close(struct fsl_mc_io *mc_io, 618 u32 cmd_flags, 619 u16 token); 620 621int dpcon_enable(struct fsl_mc_io *mc_io, 622 u32 cmd_flags, 623 u16 token); 624 625int dpcon_disable(struct fsl_mc_io *mc_io, 626 u32 cmd_flags, 627 u16 token); 628 629int dpcon_reset(struct fsl_mc_io *mc_io, 630 u32 cmd_flags, 631 u16 token); 632 633int fsl_mc_obj_open(struct fsl_mc_io *mc_io, 634 u32 cmd_flags, 635 int obj_id, 636 char *obj_type, 637 u16 *token); 638 639int fsl_mc_obj_close(struct fsl_mc_io *mc_io, 640 u32 cmd_flags, 641 u16 token); 642 643int fsl_mc_obj_reset(struct fsl_mc_io *mc_io, 644 u32 cmd_flags, 645 u16 token); 646 647/** 648 * struct dpcon_attr - Structure representing DPCON attributes 649 * @id: DPCON object ID 650 * @qbman_ch_id: Channel ID to be used by dequeue operation 651 * @num_priorities: Number of priorities for the DPCON channel (1-8) 652 */ 653struct dpcon_attr { 654 int id; 655 u16 qbman_ch_id; 656 u8 num_priorities; 657}; 658 659int dpcon_get_attributes(struct fsl_mc_io *mc_io, 660 u32 cmd_flags, 661 u16 token, 662 struct dpcon_attr *attr); 663 664/** 665 * struct dpcon_notification_cfg - Structure representing notification params 666 * @dpio_id: DPIO object ID; must be configured with a notification channel; 667 * to disable notifications set it to 'DPCON_INVALID_DPIO_ID'; 668 * @priority: Priority selection within the DPIO channel; valid values 669 * are 0-7, depending on the number of priorities in that channel 670 * @user_ctx: User context value provided with each CDAN message 671 */ 672struct dpcon_notification_cfg { 673 int dpio_id; 674 u8 priority; 675 u64 user_ctx; 676}; 677 678int dpcon_set_notification(struct fsl_mc_io *mc_io, 679 u32 cmd_flags, 680 u16 token, 681 struct dpcon_notification_cfg *cfg); 682 683#endif /* _FSL_MC_H_ */