Commit 82799c80 authored by Chunfeng Yun's avatar Chunfeng Yun Committed by Greg Kroah-Hartman

usb: xhci-mtk: add a member of num_esit

Add a member num_esit to save the number of esit, then no need
caculate it in some functions.
Signed-off-by: default avatarChunfeng Yun <chunfeng.yun@mediatek.com>
Link: https://lore.kernel.org/r/1629189389-18779-8-git-send-email-chunfeng.yun@mediatek.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 614c8c67
...@@ -297,6 +297,7 @@ static void setup_sch_info(struct xhci_ep_ctx *ep_ctx, ...@@ -297,6 +297,7 @@ static void setup_sch_info(struct xhci_ep_ctx *ep_ctx,
CTX_TO_MAX_ESIT_PAYLOAD(le32_to_cpu(ep_ctx->tx_info)); CTX_TO_MAX_ESIT_PAYLOAD(le32_to_cpu(ep_ctx->tx_info));
sch_ep->esit = get_esit(ep_ctx); sch_ep->esit = get_esit(ep_ctx);
sch_ep->num_esit = XHCI_MTK_MAX_ESIT / sch_ep->esit;
sch_ep->ep_type = ep_type; sch_ep->ep_type = ep_type;
sch_ep->maxpkt = maxpkt; sch_ep->maxpkt = maxpkt;
sch_ep->offset = 0; sch_ep->offset = 0;
...@@ -401,14 +402,12 @@ static void setup_sch_info(struct xhci_ep_ctx *ep_ctx, ...@@ -401,14 +402,12 @@ static void setup_sch_info(struct xhci_ep_ctx *ep_ctx,
static u32 get_max_bw(struct mu3h_sch_bw_info *sch_bw, static u32 get_max_bw(struct mu3h_sch_bw_info *sch_bw,
struct mu3h_sch_ep_info *sch_ep, u32 offset) struct mu3h_sch_ep_info *sch_ep, u32 offset)
{ {
u32 num_esit;
u32 max_bw = 0; u32 max_bw = 0;
u32 bw; u32 bw;
int i; int i;
int j; int j;
num_esit = XHCI_MTK_MAX_ESIT / sch_ep->esit; for (i = 0; i < sch_ep->num_esit; i++) {
for (i = 0; i < num_esit; i++) {
u32 base = offset + i * sch_ep->esit; u32 base = offset + i * sch_ep->esit;
for (j = 0; j < sch_ep->num_budget_microframes; j++) { for (j = 0; j < sch_ep->num_budget_microframes; j++) {
...@@ -424,13 +423,11 @@ static u32 get_max_bw(struct mu3h_sch_bw_info *sch_bw, ...@@ -424,13 +423,11 @@ static u32 get_max_bw(struct mu3h_sch_bw_info *sch_bw,
static void update_bus_bw(struct mu3h_sch_bw_info *sch_bw, static void update_bus_bw(struct mu3h_sch_bw_info *sch_bw,
struct mu3h_sch_ep_info *sch_ep, bool used) struct mu3h_sch_ep_info *sch_ep, bool used)
{ {
u32 num_esit;
u32 base; u32 base;
int i; int i;
int j; int j;
num_esit = XHCI_MTK_MAX_ESIT / sch_ep->esit; for (i = 0; i < sch_ep->num_esit; i++) {
for (i = 0; i < num_esit; i++) {
base = sch_ep->offset + i * sch_ep->esit; base = sch_ep->offset + i * sch_ep->esit;
for (j = 0; j < sch_ep->num_budget_microframes; j++) { for (j = 0; j < sch_ep->num_budget_microframes; j++) {
if (used) if (used)
...@@ -446,12 +443,11 @@ static void update_bus_bw(struct mu3h_sch_bw_info *sch_bw, ...@@ -446,12 +443,11 @@ static void update_bus_bw(struct mu3h_sch_bw_info *sch_bw,
static int check_fs_bus_bw(struct mu3h_sch_ep_info *sch_ep, int offset) static int check_fs_bus_bw(struct mu3h_sch_ep_info *sch_ep, int offset)
{ {
struct mu3h_sch_tt *tt = sch_ep->sch_tt; struct mu3h_sch_tt *tt = sch_ep->sch_tt;
u32 num_esit, tmp; u32 tmp;
int base; int base;
int i, j; int i, j;
num_esit = XHCI_MTK_MAX_ESIT / sch_ep->esit; for (i = 0; i < sch_ep->num_esit; i++) {
for (i = 0; i < num_esit; i++) {
base = offset + i * sch_ep->esit; base = offset + i * sch_ep->esit;
/* /*
...@@ -533,12 +529,10 @@ static int check_sch_tt(struct mu3h_sch_ep_info *sch_ep, u32 offset) ...@@ -533,12 +529,10 @@ static int check_sch_tt(struct mu3h_sch_ep_info *sch_ep, u32 offset)
static void update_sch_tt(struct mu3h_sch_ep_info *sch_ep, bool used) static void update_sch_tt(struct mu3h_sch_ep_info *sch_ep, bool used)
{ {
struct mu3h_sch_tt *tt = sch_ep->sch_tt; struct mu3h_sch_tt *tt = sch_ep->sch_tt;
u32 base, num_esit; u32 base;
int i, j; int i, j;
num_esit = XHCI_MTK_MAX_ESIT / sch_ep->esit; for (i = 0; i < sch_ep->num_esit; i++) {
for (i = 0; i < num_esit; i++) {
base = sch_ep->offset + i * sch_ep->esit; base = sch_ep->offset + i * sch_ep->esit;
for (j = 0; j < sch_ep->num_budget_microframes; j++) for (j = 0; j < sch_ep->num_budget_microframes; j++)
......
...@@ -50,6 +50,7 @@ struct mu3h_sch_bw_info { ...@@ -50,6 +50,7 @@ struct mu3h_sch_bw_info {
* struct mu3h_sch_ep_info: schedule information for endpoint * struct mu3h_sch_ep_info: schedule information for endpoint
* *
* @esit: unit is 125us, equal to 2 << Interval field in ep-context * @esit: unit is 125us, equal to 2 << Interval field in ep-context
* @num_esit: number of @esit in a period
* @num_budget_microframes: number of continuous uframes * @num_budget_microframes: number of continuous uframes
* (@repeat==1) scheduled within the interval * (@repeat==1) scheduled within the interval
* @bw_cost_per_microframe: bandwidth cost per microframe * @bw_cost_per_microframe: bandwidth cost per microframe
...@@ -79,6 +80,7 @@ struct mu3h_sch_bw_info { ...@@ -79,6 +80,7 @@ struct mu3h_sch_bw_info {
*/ */
struct mu3h_sch_ep_info { struct mu3h_sch_ep_info {
u32 esit; u32 esit;
u32 num_esit;
u32 num_budget_microframes; u32 num_budget_microframes;
u32 bw_cost_per_microframe; u32 bw_cost_per_microframe;
struct list_head endpoint; struct list_head endpoint;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment