summaryrefslogtreecommitdiffstats
path: root/drivers/irqchip/irq-mips-gic.c
AgeCommit message (Expand)Author
2018-02-16irqchip/mips-gic: Avoid spuriously handling masked interruptsMatt Redfearn
2017-11-09irqchip: mips-gic: Print warning if inherited GIC base is usedMatt Redfearn
2017-11-09irqchip/mips-gic: Add pr_fmt and reword pr_* messagesMatt Redfearn
2017-11-02irqchip: mips-gic: Make IPI bitmaps staticPaul Burton
2017-11-02irqchip: mips-gic: Share register writes in gic_set_type()Paul Burton
2017-11-02irqchip: mips-gic: Remove gic_vpes variablePaul Burton
2017-11-02irqchip: mips-gic: Use num_possible_cpus() to reserve IPIsPaul Burton
2017-11-02irqchip: mips-gic: Configure EIC when CPUs come onlinePaul Burton
2017-11-02irqchip: mips-gic: Mask local interrupts when CPUs come onlinePaul Burton
2017-11-02irqchip: mips-gic: Use irq_cpu_online to (un)mask all-VP(E) IRQsPaul Burton
2017-11-02irqchip: mips-gic: Inline gic_local_irq_domain_map()Paul Burton
2017-09-25irqchip/mips-gic: Use effective affinity to unmaskPaul Burton
2017-09-25irqchip/mips-gic: Fix shifts to extract register fieldsPaul Burton
2017-09-19irqchip.mips-gic: Fix shared interrupt mask writesPaul Burton
2017-09-15Merge branch '4.14-features' of git://git.linux-mips.org/pub/scm/ralf/upstrea...Linus Torvalds
2017-09-04Merge branch 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kerne...Linus Torvalds
2017-09-04irqchip: mips-gic: Let the core set struct irq_common_data affinityPaul Burton
2017-09-04irqchip: mips-gic: Use cpumask_first_and() in gic_set_affinity()Paul Burton
2017-09-04irqchip: mips-gic: Clean up mti, reserved-cpu-vectors handlingPaul Burton
2017-09-04irqchip: mips-gic: Use pcpu_masks to avoid reading GIC_SH_MASK*Paul Burton
2017-09-04irqchip: mips-gic: Make pcpu_masks a per-cpu variablePaul Burton
2017-09-04irqchip: mips-gic: Inline gic_basic_init()Paul Burton
2017-09-04irqchip: mips-gic: Inline __gic_init()Paul Burton
2017-09-04irqchip: mips-gic: Move gic_get_c0_*_int() to asm/mips-gic.hPaul Burton
2017-09-04irqchip: mips-gic: Remove gic_presentPaul Burton
2017-09-04irqchip: mips-gic: Remove gic_init()Paul Burton
2017-09-04irqchip: mips-gic: Remove __gic_irq_dispatch() forward declarationPaul Burton
2017-09-04irqchip: mips-gic: Remove gic_get_usm_range()Paul Burton
2017-09-04irqchip: mips-gic: Move various definitions to the driverPaul Burton
2017-09-04irqchip: mips-gic: Convert remaining local reg access to new accessorsPaul Burton
2017-09-04irqchip: mips-gic: Convert local int mask access to new accessorsPaul Burton
2017-09-04irqchip: mips-gic: Convert remaining shared reg access to new accessorsPaul Burton
2017-09-04irqchip: mips-gic: Remove gic_map_to_vpe()Paul Burton
2017-09-04irqchip: mips-gic: Remove gic_map_to_pin()Paul Burton
2017-09-04irqchip: mips-gic: Remove gic_set_dual_edge()Paul Burton
2017-09-04irqchip: mips-gic: Remove gic_set_trigger()Paul Burton
2017-09-04irqchip: mips-gic: Remove gic_set_polarity()Paul Burton
2017-09-04irqchip: mips-gic: Drop gic_(re)set_mask() functionsPaul Burton
2017-09-04irqchip: mips-gic: Simplify gic_local_irq_domain_map()Paul Burton
2017-09-04irqchip: mips-gic: Simplify shared interrupt pending/mask readsPaul Burton
2017-09-04irqchip: mips-gic: Remove gic_read_local_vp_id()Paul Burton
2017-09-04irqchip: mips-gic: Remove counter access functionsPaul Burton
2017-08-30MIPS: GIC: Introduce asm/mips-gic.h with accessor functionsPaul Burton
2017-08-30irqchip: mips-gic: SYNC after enabling GIC regionJames Hogan
2017-08-30irqchip: mips-gic: SYNC after enabling GIC regionJames Hogan
2017-08-30MIPS: CPS: Have asm/mips-cps.h include CM & CPC headersPaul Burton
2017-08-29MIPS: CM: Use BIT/GENMASK for register fields, order & drop shiftsPaul Burton
2017-08-18irqchip/mips-gic: Report that effective affinity is a single targetMarc Zyngier
2017-07-18irqchip/mips-gic: Remove population of irq domain namesMatt Redfearn
2017-07-03Merge branch 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kerne...Linus Torvalds
include <ctype.h> #include <stdlib.h> #include <string.h> #include <time.h> #include "tmux.h" /* * Prompt for command in client. */ void cmd_command_prompt_key_binding(struct cmd *, int); int cmd_command_prompt_check(struct args *); enum cmd_retval cmd_command_prompt_exec(struct cmd *, struct cmd_ctx *); int cmd_command_prompt_callback(void *, const char *); void cmd_command_prompt_free(void *); const struct cmd_entry cmd_command_prompt_entry = { "command-prompt", NULL, "I:p:t:", 0, 1, "[-I inputs] [-p prompts] " CMD_TARGET_CLIENT_USAGE " [template]", 0, cmd_command_prompt_key_binding, NULL, cmd_command_prompt_exec }; struct cmd_command_prompt_cdata { struct client *c; char *inputs; char *next_input; char *next_prompt; char *prompts; char *template; int idx; }; void cmd_command_prompt_key_binding(struct cmd *self, int key) { switch (key) { case '$': self->args = args_create(1, "rename-session '%%'"); args_set(self->args, 'I', "#S"); break; case ',': self->args = args_create(1, "rename-window '%%'"); args_set(self->args, 'I', "#W"); break; case '.': self->args = args_create(1, "move-window -t '%%'"); break; case 'f': self->args = args_create(1, "find-window '%%'"); break; case '\'': self->args = args_create(1, "select-window -t ':%%'"); args_set(self->args, 'p', "index"); break; default: self->args = args_create(0); break; } } enum cmd_retval cmd_command_prompt_exec(struct cmd *self, struct cmd_ctx *ctx) { struct args *args = self->args; const char *inputs, *prompts; struct cmd_command_prompt_cdata *cdata; struct client *c; char *prompt, *ptr, *input = NULL; size_t n; if ((c = cmd_find_client(ctx, args_get(args, 't'))) == NULL) return (CMD_RETURN_ERROR); if (c->prompt_string != NULL) return (CMD_RETURN_NORMAL); cdata = xmalloc(sizeof *cdata); cdata->c = c; cdata->idx = 1; cdata->inputs = NULL; cdata->next_input = NULL; cdata->next_prompt = NULL; cdata->prompts = NULL; cdata->template = NULL; if (args->argc != 0) cdata->template = xstrdup(args->argv[0]); else cdata->template = xstrdup("%1"); if ((prompts = args_get(args, 'p')) != NULL) cdata->prompts = xstrdup(prompts); else if (args->argc != 0) { n = strcspn(cdata->template, " ,"); xasprintf(&cdata->prompts, "(%.*s) ", (int) n, cdata->template); } else cdata->prompts = xstrdup(":"); /* Get first prompt. */ cdata->next_prompt = cdata->prompts; ptr = strsep(&cdata->next_prompt, ","); if (prompts == NULL) prompt = xstrdup(ptr); else xasprintf(&prompt, "%s ", ptr); /* Get initial prompt input. */ if ((inputs = args_get(args, 'I')) != NULL) { cdata->inputs = xstrdup(inputs); cdata->next_input = cdata->inputs; input = strsep(&cdata->next_input, ","); } status_prompt_set(c, prompt, input, cmd_command_prompt_callback, cmd_command_prompt_free, cdata, 0); free(prompt); return (CMD_RETURN_NORMAL); } int cmd_command_prompt_callback(void *data, const char *s) { struct cmd_command_prompt_cdata *cdata = data; struct client *c = cdata->c; struct cmd_list *cmdlist; struct cmd_ctx ctx; char *cause, *new_template, *prompt, *ptr; char *input = NULL; if (s == NULL) return (0); new_template = cmd_template_replace(cdata->template, s, cdata->idx); free(cdata->template); cdata->template = new_template; /* * Check if there are more prompts; if so, get its respective input * and update the prompt data. */ if ((ptr = strsep(&cdata->next_prompt, ",")) != NULL) { xasprintf(&prompt, "%s ", ptr); input = strsep(&cdata->next_input, ","); status_prompt_update(c, prompt, input); free(prompt); cdata->idx++; return (1); } if (cmd_string_parse(new_template, &cmdlist, &cause) != 0) { if (cause != NULL) { *cause = toupper((u_char) *cause); status_message_set(c, "%s", cause); free(cause); } return (0); } ctx.msgdata = NULL; ctx.curclient = c; ctx.error = key_bindings_error; ctx.print = key_bindings_print; ctx.info = key_bindings_info; ctx.cmdclient = NULL; cmd_list_exec(cmdlist, &ctx); cmd_list_free(cmdlist); if (c->prompt_callbackfn != (void *) &cmd_command_prompt_callback) return (1); return (0); } void cmd_command_prompt_free(void *data) { struct cmd_command_prompt_cdata *cdata = data; free(cdata->inputs); free(cdata->prompts); free(cdata->template); free(cdata); }