Lines Matching +full:out +full:-

1 // SPDX-License-Identifier: GPL-2.0-or-later
16 #include <linux/pinctrl/pinconf-generic.h>
21 #include <dt-bindings/pinctrl/k210-fpioa.h>
25 #include "pinctrl-utils.h"
50 #define K210_PC_DO_OE BIT(14) /* set Data Out to Output Enable sig */
81 * @pins: 48 32-bits IO pin registers
132 * no pins 48-55).
178 K210_PC_DEFAULT(OUT),
206 K210_FUNC(JTAG_TDO, OUT),
215 K210_FUNC(SPI0_SS0, OUT),
216 K210_FUNC(SPI0_SS1, OUT),
217 K210_FUNC(SPI0_SS2, OUT),
218 K210_FUNC(SPI0_SS3, OUT),
220 K210_FUNC(SPI0_SCLK, OUT),
222 K210_FUNC(UARTHS_TX, OUT),
225 K210_FUNC(CLK_SPI1, OUT),
226 K210_FUNC(CLK_I2C1, OUT),
268 K210_FUNC(UART1_TX, OUT),
270 K210_FUNC(UART2_TX, OUT),
272 K210_FUNC(UART3_TX, OUT),
281 K210_FUNC(SPI1_SS0, OUT),
282 K210_FUNC(SPI1_SS1, OUT),
283 K210_FUNC(SPI1_SS2, OUT),
284 K210_FUNC(SPI1_SS3, OUT),
286 K210_FUNC(SPI1_SCLK, OUT),
290 K210_FUNC(I2S0_MCLK, OUT),
291 K210_FUNC(I2S0_SCLK, OUT),
292 K210_FUNC(I2S0_WS, OUT),
297 K210_FUNC(I2S0_OUT_D0, OUT),
298 K210_FUNC(I2S0_OUT_D1, OUT),
299 K210_FUNC(I2S0_OUT_D2, OUT),
300 K210_FUNC(I2S0_OUT_D3, OUT),
301 K210_FUNC(I2S1_MCLK, OUT),
302 K210_FUNC(I2S1_SCLK, OUT),
303 K210_FUNC(I2S1_WS, OUT),
308 K210_FUNC(I2S1_OUT_D0, OUT),
309 K210_FUNC(I2S1_OUT_D1, OUT),
310 K210_FUNC(I2S1_OUT_D2, OUT),
311 K210_FUNC(I2S1_OUT_D3, OUT),
312 K210_FUNC(I2S2_MCLK, OUT),
313 K210_FUNC(I2S2_SCLK, OUT),
314 K210_FUNC(I2S2_WS, OUT),
319 K210_FUNC(I2S2_OUT_D0, OUT),
320 K210_FUNC(I2S2_OUT_D1, OUT),
321 K210_FUNC(I2S2_OUT_D2, OUT),
322 K210_FUNC(I2S2_OUT_D3, OUT),
335 K210_FUNC(DVP_XCLK, OUT),
336 K210_FUNC(DVP_RST, OUT),
337 K210_FUNC(DVP_PWDN, OUT),
356 K210_FUNC(UART1_DTR, OUT),
357 K210_FUNC(UART1_RTS, OUT),
358 K210_FUNC(UART1_OUT2, OUT),
359 K210_FUNC(UART1_OUT1, OUT),
360 K210_FUNC(UART1_SIR_OUT, OUT),
361 K210_FUNC(UART1_BAUD, OUT),
362 K210_FUNC(UART1_RE, OUT),
363 K210_FUNC(UART1_DE, OUT),
364 K210_FUNC(UART1_RS485_EN, OUT),
370 K210_FUNC(UART2_DTR, OUT),
371 K210_FUNC(UART2_RTS, OUT),
372 K210_FUNC(UART2_OUT2, OUT),
373 K210_FUNC(UART2_OUT1, OUT),
374 K210_FUNC(UART2_SIR_OUT, OUT),
375 K210_FUNC(UART2_BAUD, OUT),
376 K210_FUNC(UART2_RE, OUT),
377 K210_FUNC(UART2_DE, OUT),
378 K210_FUNC(UART2_RS485_EN, OUT),
384 K210_FUNC(UART3_DTR, OUT),
385 K210_FUNC(UART3_RTS, OUT),
386 K210_FUNC(UART3_OUT2, OUT),
387 K210_FUNC(UART3_OUT1, OUT),
388 K210_FUNC(UART3_SIR_OUT, OUT),
389 K210_FUNC(UART3_BAUD, OUT),
390 K210_FUNC(UART3_RE, OUT),
391 K210_FUNC(UART3_DE, OUT),
392 K210_FUNC(UART3_RS485_EN, OUT),
393 K210_FUNC(TIMER0_TOGGLE1, OUT),
394 K210_FUNC(TIMER0_TOGGLE2, OUT),
395 K210_FUNC(TIMER0_TOGGLE3, OUT),
396 K210_FUNC(TIMER0_TOGGLE4, OUT),
397 K210_FUNC(TIMER1_TOGGLE1, OUT),
398 K210_FUNC(TIMER1_TOGGLE2, OUT),
399 K210_FUNC(TIMER1_TOGGLE3, OUT),
400 K210_FUNC(TIMER1_TOGGLE4, OUT),
401 K210_FUNC(TIMER2_TOGGLE1, OUT),
402 K210_FUNC(TIMER2_TOGGLE2, OUT),
403 K210_FUNC(TIMER2_TOGGLE3, OUT),
404 K210_FUNC(TIMER2_TOGGLE4, OUT),
405 K210_FUNC(CLK_SPI2, OUT),
406 K210_FUNC(CLK_I2C2, OUT),
407 K210_FUNC(INTERNAL0, OUT),
408 K210_FUNC(INTERNAL1, OUT),
409 K210_FUNC(INTERNAL2, OUT),
410 K210_FUNC(INTERNAL3, OUT),
411 K210_FUNC(INTERNAL4, OUT),
412 K210_FUNC(INTERNAL5, OUT),
413 K210_FUNC(INTERNAL6, OUT),
414 K210_FUNC(INTERNAL7, OUT),
415 K210_FUNC(INTERNAL8, OUT),
427 K210_FUNC(DEBUG0, OUT),
428 K210_FUNC(DEBUG1, OUT),
429 K210_FUNC(DEBUG2, OUT),
430 K210_FUNC(DEBUG3, OUT),
431 K210_FUNC(DEBUG4, OUT),
432 K210_FUNC(DEBUG5, OUT),
433 K210_FUNC(DEBUG6, OUT),
434 K210_FUNC(DEBUG7, OUT),
435 K210_FUNC(DEBUG8, OUT),
436 K210_FUNC(DEBUG9, OUT),
437 K210_FUNC(DEBUG10, OUT),
438 K210_FUNC(DEBUG11, OUT),
439 K210_FUNC(DEBUG12, OUT),
440 K210_FUNC(DEBUG13, OUT),
441 K210_FUNC(DEBUG14, OUT),
442 K210_FUNC(DEBUG15, OUT),
443 K210_FUNC(DEBUG16, OUT),
444 K210_FUNC(DEBUG17, OUT),
445 K210_FUNC(DEBUG18, OUT),
446 K210_FUNC(DEBUG19, OUT),
447 K210_FUNC(DEBUG20, OUT),
448 K210_FUNC(DEBUG21, OUT),
449 K210_FUNC(DEBUG22, OUT),
450 K210_FUNC(DEBUG23, OUT),
451 K210_FUNC(DEBUG24, OUT),
452 K210_FUNC(DEBUG25, OUT),
453 K210_FUNC(DEBUG26, OUT),
454 K210_FUNC(DEBUG27, OUT),
455 K210_FUNC(DEBUG28, OUT),
456 K210_FUNC(DEBUG29, OUT),
457 K210_FUNC(DEBUG30, OUT),
458 K210_FUNC(DEBUG31, OUT),
465 { "output-polarity-invert", PIN_CONFIG_OUTPUT_INVERT, 1 },
466 { "input-polarity-invert", PIN_CONFIG_INPUT_INVERT, 1 },
487 for (i = K210_PC_DRIVE_MAX; i >= 0; i--) { in k210_pinconf_get_drive()
492 return -EINVAL; in k210_pinconf_get_drive()
500 u32 mode = k210_pinconf_mode_id_to_mode[info->mode_id]; in k210_pinmux_set_pin_function()
503 dev_dbg(pdata->dev, "set pin %u function %s (%u) -> 0x%08x\n", in k210_pinmux_set_pin_function()
504 pin, info->name, func, val); in k210_pinmux_set_pin_function()
506 writel(val, &pdata->fpioa->pins[pin]); in k210_pinmux_set_pin_function()
514 u32 val = readl(&pdata->fpioa->pins[pin]); in k210_pinconf_set_param()
517 dev_dbg(pdata->dev, "set pin %u param %u, arg 0x%x\n", in k210_pinconf_set_param()
526 return -EINVAL; in k210_pinconf_set_param()
531 return -EINVAL; in k210_pinconf_set_param()
558 val = readl(&pdata->fpioa->pins[pin]); in k210_pinconf_set_param()
588 return -EINVAL; in k210_pinconf_set_param()
591 writel(val, &pdata->fpioa->pins[pin]); in k210_pinconf_set_param()
603 return -EINVAL; in k210_pinconf_set()
621 seq_printf(s, "%#x", readl(&pdata->fpioa->pins[pin])); in k210_pinconf_dbg_show()
635 return -EINVAL; in k210_pinconf_group_set()
641 return -EINVAL; in k210_pinconf_group_set()
644 bit = BIT(selector - K210_NPINS); in k210_pinconf_group_set()
645 regmap_update_bits(pdata->sysctl_map, in k210_pinconf_group_set()
646 pdata->power_offset, in k210_pinconf_group_set()
664 ret = regmap_read(pdata->sysctl_map, pdata->power_offset, &val); in k210_pinconf_group_dbg_show()
666 dev_err(pdata->dev, "Failed to read power reg\n"); in k210_pinconf_group_dbg_show()
671 val & BIT(selector - K210_NPINS) ? "1.8" : "3.3"); in k210_pinconf_group_dbg_show()
711 return -EINVAL; in k210_pinmux_set_mux()
757 seq_printf(s, "%s", dev_name(pctldev->dev)); in k210_pinctrl_pin_dbg_show()
787 dev_err(pctldev->dev, "%pOF: could not parse node property\n", in k210_pinctrl_dt_subnode_to_map()
804 ret = -EINVAL; in k210_pinctrl_dt_subnode_to_map()
811 dev_dbg(pctldev->dev, "Pinmux %s: pin %u func %s\n", in k210_pinctrl_dt_subnode_to_map()
812 np->name, pin, func_name); in k210_pinctrl_dt_subnode_to_map()
818 dev_err(pctldev->dev, "%pOF add mux map failed %d\n", in k210_pinctrl_dt_subnode_to_map()
829 dev_err(pctldev->dev, in k210_pinctrl_dt_subnode_to_map()
885 .name = "k210-pinctrl",
897 struct k210_fpioa __iomem *fpioa = pdata->fpioa; in k210_fpioa_init_ties()
901 dev_dbg(pdata->dev, "Init pin ties\n"); in k210_fpioa_init_ties()
904 for (i = 0; i < ARRAY_SIZE(fpioa->tie_en); i++) { in k210_fpioa_init_ties()
909 dev_dbg(pdata->dev, in k210_fpioa_init_ties()
918 writel(val, &fpioa->tie_val[i]); in k210_fpioa_init_ties()
919 writel(val, &fpioa->tie_en[i]); in k210_fpioa_init_ties()
925 struct device *dev = &pdev->dev; in k210_fpioa_probe()
926 struct device_node *np = dev->of_node; in k210_fpioa_probe()
933 return -ENOMEM; in k210_fpioa_probe()
935 pdata->dev = dev; in k210_fpioa_probe()
938 pdata->fpioa = devm_platform_ioremap_resource(pdev, 0); in k210_fpioa_probe()
939 if (IS_ERR(pdata->fpioa)) in k210_fpioa_probe()
940 return PTR_ERR(pdata->fpioa); in k210_fpioa_probe()
942 pdata->clk = devm_clk_get_enabled(dev, "ref"); in k210_fpioa_probe()
943 if (IS_ERR(pdata->clk)) in k210_fpioa_probe()
944 return PTR_ERR(pdata->clk); in k210_fpioa_probe()
946 pdata->pclk = devm_clk_get_optional_enabled(dev, "pclk"); in k210_fpioa_probe()
947 if (IS_ERR(pdata->pclk)) in k210_fpioa_probe()
948 return PTR_ERR(pdata->pclk); in k210_fpioa_probe()
950 pdata->sysctl_map = in k210_fpioa_probe()
952 "canaan,k210-sysctl-power", in k210_fpioa_probe()
953 1, &pdata->power_offset); in k210_fpioa_probe()
954 if (IS_ERR(pdata->sysctl_map)) in k210_fpioa_probe()
955 return PTR_ERR(pdata->sysctl_map); in k210_fpioa_probe()
959 pdata->pctl = pinctrl_register(&k210_pinctrl_desc, dev, (void *)pdata); in k210_fpioa_probe()
960 if (IS_ERR(pdata->pctl)) in k210_fpioa_probe()
961 return PTR_ERR(pdata->pctl); in k210_fpioa_probe()
967 { .compatible = "canaan,k210-fpioa" },
974 .name = "k210-fpioa",