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