.attrs = tty_dev_attrs,
        };
 
-static const struct attribute_group *tty_dev_attr_groups[] = {
-       &tty_dev_attr_group,
-       NULL
-       };
-
-
 /**
  *     uart_add_one_port - attach a driver-defined port structure
  *     @drv: pointer to the uart low level driver structure for this port
        struct tty_port *port;
        int ret = 0;
        struct device *tty_dev;
+       int num_groups;
 
        BUG_ON(in_interrupt());
 
 
        uart_configure_port(drv, state, uport);
 
+       num_groups = 2;
+       if (uport->attr_group)
+               num_groups++;
+
+       uport->tty_groups = kcalloc(num_groups, sizeof(**uport->tty_groups),
+                                   GFP_KERNEL);
+       if (!uport->tty_groups) {
+               ret = -ENOMEM;
+               goto out;
+       }
+       uport->tty_groups[0] = &tty_dev_attr_group;
+       if (uport->attr_group)
+               uport->tty_groups[1] = uport->attr_group;
+
        /*
         * Register the port whether it's detected or not.  This allows
         * setserial to be used to alter this port's parameters.
         */
        tty_dev = tty_port_register_device_attr(port, drv->tty_driver,
-                       uport->line, uport->dev, port, tty_dev_attr_groups);
+                       uport->line, uport->dev, port, uport->tty_groups);
        if (likely(!IS_ERR(tty_dev))) {
                device_set_wakeup_capable(tty_dev, 1);
        } else {
         */
        if (uport->type != PORT_UNKNOWN)
                uport->ops->release_port(uport);
+       kfree(uport->tty_groups);
 
        /*
         * Indicate that there isn't a port here anymore.