|
@@ -632,6 +632,31 @@ static int rockchip_get_mux(struct rockchip_pin_bank *bank, int pin)
|
|
|
return ((val >> bit) & mask);
|
|
|
}
|
|
|
|
|
|
+static int rockchip_verify_mux(struct rockchip_pin_bank *bank,
|
|
|
+ int pin, int mux)
|
|
|
+{
|
|
|
+ struct rockchip_pinctrl *info = bank->drvdata;
|
|
|
+ int iomux_num = (pin / 8);
|
|
|
+
|
|
|
+ if (iomux_num > 3)
|
|
|
+ return -EINVAL;
|
|
|
+
|
|
|
+ if (bank->iomux[iomux_num].type & IOMUX_UNROUTED) {
|
|
|
+ dev_err(info->dev, "pin %d is unrouted\n", pin);
|
|
|
+ return -EINVAL;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (bank->iomux[iomux_num].type & IOMUX_GPIO_ONLY) {
|
|
|
+ if (mux != RK_FUNC_GPIO) {
|
|
|
+ dev_err(info->dev,
|
|
|
+ "pin %d only supports a gpio mux\n", pin);
|
|
|
+ return -ENOTSUPP;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
/*
|
|
|
* Set a new mux function for a pin.
|
|
|
*
|
|
@@ -655,23 +680,12 @@ static int rockchip_set_mux(struct rockchip_pin_bank *bank, int pin, int mux)
|
|
|
u8 bit;
|
|
|
u32 data, rmask;
|
|
|
|
|
|
- if (iomux_num > 3)
|
|
|
- return -EINVAL;
|
|
|
-
|
|
|
- if (bank->iomux[iomux_num].type & IOMUX_UNROUTED) {
|
|
|
- dev_err(info->dev, "pin %d is unrouted\n", pin);
|
|
|
- return -EINVAL;
|
|
|
- }
|
|
|
+ ret = rockchip_verify_mux(bank, pin, mux);
|
|
|
+ if (ret < 0)
|
|
|
+ return ret;
|
|
|
|
|
|
- if (bank->iomux[iomux_num].type & IOMUX_GPIO_ONLY) {
|
|
|
- if (mux != RK_FUNC_GPIO) {
|
|
|
- dev_err(info->dev,
|
|
|
- "pin %d only supports a gpio mux\n", pin);
|
|
|
- return -ENOTSUPP;
|
|
|
- } else {
|
|
|
- return 0;
|
|
|
- }
|
|
|
- }
|
|
|
+ if (bank->iomux[iomux_num].type & IOMUX_GPIO_ONLY)
|
|
|
+ return 0;
|
|
|
|
|
|
dev_dbg(info->dev, "setting mux of GPIO%d-%d to %d\n",
|
|
|
bank->bank_num, pin, mux);
|