Skip to content

Commit

Permalink
staging: fsl-mc: Move DPBP out of staging
Browse files Browse the repository at this point in the history
Move the source files out of staging into their final locations:
- dpbp.c goes to drivers/bus/fsl-mc/, next to the core infrastructure
- dpbp-cmd.h gets merged into drivers/bus/fsl-mc/fsl-mc-private.h, next
  to the other internally used APIs
- dpbp.h gets merged into include/linux/fsl/mc.h, exposing the public
  API

Update references in the dpaa2-eth staging driver.

DPBP stands for Data Path Buffer Pool - you can read more about the
object in Documentation/networking/dpaa2/overview.rst

Signed-off-by: Bogdan Purcareata <[email protected]>
Reviewed-by: Laurentiu Tudor <[email protected]>
Signed-off-by: Greg Kroah-Hartman <[email protected]>
  • Loading branch information
Bogdan Purcareata authored and gregkh committed Mar 14, 2018
1 parent d64c2a7 commit 9c692d5
Show file tree
Hide file tree
Showing 8 changed files with 86 additions and 102 deletions.
1 change: 1 addition & 0 deletions drivers/bus/fsl-mc/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ obj-$(CONFIG_FSL_MC_BUS) += mc-bus-driver.o
mc-bus-driver-objs := fsl-mc-bus.o \
mc-sys.o \
mc-io.o \
dpbp.o \
dprc.o \
dprc-driver.o \
fsl-mc-allocator.o \
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@
*/
#include <linux/kernel.h>
#include <linux/fsl/mc.h>
#include "../include/dpbp.h"
#include <linux/fsl/mc.h>

#include "dpbp-cmd.h"
#include "fsl-mc-private.h"

/**
* dpbp_open() - Open a control session for the specified object.
Expand Down
39 changes: 39 additions & 0 deletions drivers/bus/fsl-mc/fsl-mc-private.h
Original file line number Diff line number Diff line change
Expand Up @@ -379,6 +379,45 @@ int dprc_get_container_id(struct fsl_mc_io *mc_io,
u32 cmd_flags,
int *container_id);

/*
* Data Path Buffer Pool (DPBP) API
*/

/* DPBP Version */
#define DPBP_VER_MAJOR 3
#define DPBP_VER_MINOR 2

/* Command versioning */
#define DPBP_CMD_BASE_VERSION 1
#define DPBP_CMD_ID_OFFSET 4

#define DPBP_CMD(id) (((id) << DPBP_CMD_ID_OFFSET) | DPBP_CMD_BASE_VERSION)

/* Command IDs */
#define DPBP_CMDID_CLOSE DPBP_CMD(0x800)
#define DPBP_CMDID_OPEN DPBP_CMD(0x804)

#define DPBP_CMDID_ENABLE DPBP_CMD(0x002)
#define DPBP_CMDID_DISABLE DPBP_CMD(0x003)
#define DPBP_CMDID_GET_ATTR DPBP_CMD(0x004)
#define DPBP_CMDID_RESET DPBP_CMD(0x005)

struct dpbp_cmd_open {
__le32 dpbp_id;
};

#define DPBP_ENABLE 0x1

struct dpbp_rsp_get_attributes {
/* response word 0 */
__le16 pad;
__le16 bpid;
__le32 id;
/* response word 1 */
__le16 version_major;
__le16 version_minor;
};

/**
* Maximum number of total IRQs that can be pre-allocated for an MC bus'
* IRQ pool
Expand Down
2 changes: 1 addition & 1 deletion drivers/staging/fsl-dpaa2/ethernet/dpaa2-eth.h
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,10 @@

#include <linux/netdevice.h>
#include <linux/if_vlan.h>
#include <linux/fsl/mc.h>

#include "../../fsl-mc/include/dpaa2-io.h"
#include "../../fsl-mc/include/dpaa2-fd.h"
#include "../../fsl-mc/include/dpbp.h"
#include "../../fsl-mc/include/dpcon.h"
#include "dpni.h"
#include "dpni-cmd.h"
Expand Down
3 changes: 1 addition & 2 deletions drivers/staging/fsl-mc/bus/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,7 @@
#
# Copyright (C) 2014 Freescale Semiconductor, Inc.
#
obj-$(CONFIG_FSL_MC_BUS) += dpbp.o \
dpcon.o
obj-$(CONFIG_FSL_MC_BUS) += dpcon.o

# MC DPIO driver
obj-$(CONFIG_FSL_MC_DPIO) += dpio/
44 changes: 0 additions & 44 deletions drivers/staging/fsl-mc/bus/dpbp-cmd.h

This file was deleted.

53 changes: 0 additions & 53 deletions drivers/staging/fsl-mc/include/dpbp.h

This file was deleted.

42 changes: 42 additions & 0 deletions include/linux/fsl/mc.h
Original file line number Diff line number Diff line change
Expand Up @@ -451,4 +451,46 @@ static inline bool is_fsl_mc_bus_dprtc(const struct fsl_mc_device *mc_dev)
return mc_dev->dev.type == &fsl_mc_bus_dprtc_type;
}

/*
* Data Path Buffer Pool (DPBP) API
* Contains initialization APIs and runtime control APIs for DPBP
*/

int dpbp_open(struct fsl_mc_io *mc_io,
u32 cmd_flags,
int dpbp_id,
u16 *token);

int dpbp_close(struct fsl_mc_io *mc_io,
u32 cmd_flags,
u16 token);

int dpbp_enable(struct fsl_mc_io *mc_io,
u32 cmd_flags,
u16 token);

int dpbp_disable(struct fsl_mc_io *mc_io,
u32 cmd_flags,
u16 token);

int dpbp_reset(struct fsl_mc_io *mc_io,
u32 cmd_flags,
u16 token);

/**
* struct dpbp_attr - Structure representing DPBP attributes
* @id: DPBP object ID
* @bpid: Hardware buffer pool ID; should be used as an argument in
* acquire/release operations on buffers
*/
struct dpbp_attr {
int id;
u16 bpid;
};

int dpbp_get_attributes(struct fsl_mc_io *mc_io,
u32 cmd_flags,
u16 token,
struct dpbp_attr *attr);

#endif /* _FSL_MC_H_ */

0 comments on commit 9c692d5

Please sign in to comment.