diff options
32 files changed, 605 insertions, 311 deletions
diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c index 4d2905996751..a699f09ddf7c 100644 --- a/drivers/bluetooth/btusb.c +++ b/drivers/bluetooth/btusb.c | |||
| @@ -307,6 +307,7 @@ static void btusb_bulk_complete(struct urb *urb) | |||
| 307 | return; | 307 | return; |
| 308 | 308 | ||
| 309 | usb_anchor_urb(urb, &data->bulk_anchor); | 309 | usb_anchor_urb(urb, &data->bulk_anchor); |
| 310 | usb_mark_last_busy(data->udev); | ||
| 310 | 311 | ||
| 311 | err = usb_submit_urb(urb, GFP_ATOMIC); | 312 | err = usb_submit_urb(urb, GFP_ATOMIC); |
| 312 | if (err < 0) { | 313 | if (err < 0) { |
diff --git a/drivers/isdn/mISDN/l1oip_core.c b/drivers/isdn/mISDN/l1oip_core.c index 7e5f30dbc0a0..f1e8af54dff0 100644 --- a/drivers/isdn/mISDN/l1oip_core.c +++ b/drivers/isdn/mISDN/l1oip_core.c | |||
| @@ -661,7 +661,7 @@ l1oip_socket_thread(void *data) | |||
| 661 | size_t recvbuf_size = 1500; | 661 | size_t recvbuf_size = 1500; |
| 662 | int recvlen; | 662 | int recvlen; |
| 663 | struct socket *socket = NULL; | 663 | struct socket *socket = NULL; |
| 664 | DECLARE_COMPLETION(wait); | 664 | DECLARE_COMPLETION_ONSTACK(wait); |
| 665 | 665 | ||
| 666 | /* allocate buffer memory */ | 666 | /* allocate buffer memory */ |
| 667 | recvbuf = kmalloc(recvbuf_size, GFP_KERNEL); | 667 | recvbuf = kmalloc(recvbuf_size, GFP_KERNEL); |
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c index 4bfc80812926..65df1de447e4 100644 --- a/drivers/net/bnx2.c +++ b/drivers/net/bnx2.c | |||
| @@ -653,12 +653,20 @@ static void | |||
| 653 | bnx2_netif_stop(struct bnx2 *bp) | 653 | bnx2_netif_stop(struct bnx2 *bp) |
| 654 | { | 654 | { |
| 655 | bnx2_cnic_stop(bp); | 655 | bnx2_cnic_stop(bp); |
| 656 | bnx2_disable_int_sync(bp); | ||
| 657 | if (netif_running(bp->dev)) { | 656 | if (netif_running(bp->dev)) { |
| 657 | int i; | ||
| 658 | |||
| 658 | bnx2_napi_disable(bp); | 659 | bnx2_napi_disable(bp); |
| 659 | netif_tx_disable(bp->dev); | 660 | netif_tx_disable(bp->dev); |
| 660 | bp->dev->trans_start = jiffies; /* prevent tx timeout */ | 661 | /* prevent tx timeout */ |
| 662 | for (i = 0; i < bp->dev->num_tx_queues; i++) { | ||
| 663 | struct netdev_queue *txq; | ||
| 664 | |||
| 665 | txq = netdev_get_tx_queue(bp->dev, i); | ||
| 666 | txq->trans_start = jiffies; | ||
| 667 | } | ||
| 661 | } | 668 | } |
| 669 | bnx2_disable_int_sync(bp); | ||
| 662 | } | 670 | } |
| 663 | 671 | ||
| 664 | static void | 672 | static void |
diff --git a/drivers/net/can/at91_can.c b/drivers/net/can/at91_can.c index d0ec17878ffc..166cc7e579c0 100644 --- a/drivers/net/can/at91_can.c +++ b/drivers/net/can/at91_can.c | |||
| @@ -1037,7 +1037,7 @@ static int __init at91_can_probe(struct platform_device *pdev) | |||
| 1037 | 1037 | ||
| 1038 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 1038 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
| 1039 | irq = platform_get_irq(pdev, 0); | 1039 | irq = platform_get_irq(pdev, 0); |
| 1040 | if (!res || !irq) { | 1040 | if (!res || irq <= 0) { |
| 1041 | err = -ENODEV; | 1041 | err = -ENODEV; |
| 1042 | goto exit_put; | 1042 | goto exit_put; |
| 1043 | } | 1043 | } |
diff --git a/drivers/net/davinci_emac.c b/drivers/net/davinci_emac.c index 8edac8915ea8..34e03104c3c1 100644 --- a/drivers/net/davinci_emac.c +++ b/drivers/net/davinci_emac.c | |||
| @@ -2272,7 +2272,7 @@ static int emac_mii_reset(struct mii_bus *bus) | |||
| 2272 | unsigned int clk_div; | 2272 | unsigned int clk_div; |
| 2273 | int mdio_bus_freq = emac_bus_frequency; | 2273 | int mdio_bus_freq = emac_bus_frequency; |
| 2274 | 2274 | ||
| 2275 | if (mdio_max_freq & mdio_bus_freq) | 2275 | if (mdio_max_freq && mdio_bus_freq) |
| 2276 | clk_div = ((mdio_bus_freq / mdio_max_freq) - 1); | 2276 | clk_div = ((mdio_bus_freq / mdio_max_freq) - 1); |
| 2277 | else | 2277 | else |
| 2278 | clk_div = 0xFF; | 2278 | clk_div = 0xFF; |
diff --git a/drivers/net/e100.c b/drivers/net/e100.c index 929701ca07d3..839fb2b136d3 100644 --- a/drivers/net/e100.c +++ b/drivers/net/e100.c | |||
| @@ -1829,6 +1829,7 @@ static int e100_alloc_cbs(struct nic *nic) | |||
| 1829 | &nic->cbs_dma_addr); | 1829 | &nic->cbs_dma_addr); |
| 1830 | if (!nic->cbs) | 1830 | if (!nic->cbs) |
| 1831 | return -ENOMEM; | 1831 | return -ENOMEM; |
| 1832 | memset(nic->cbs, 0, count * sizeof(struct cb)); | ||
| 1832 | 1833 | ||
| 1833 | for (cb = nic->cbs, i = 0; i < count; cb++, i++) { | 1834 | for (cb = nic->cbs, i = 0; i < count; cb++, i++) { |
| 1834 | cb->next = (i + 1 < count) ? cb + 1 : nic->cbs; | 1835 | cb->next = (i + 1 < count) ? cb + 1 : nic->cbs; |
| @@ -1837,7 +1838,6 @@ static int e100_alloc_cbs(struct nic *nic) | |||
| 1837 | cb->dma_addr = nic->cbs_dma_addr + i * sizeof(struct cb); | 1838 | cb->dma_addr = nic->cbs_dma_addr + i * sizeof(struct cb); |
| 1838 | cb->link = cpu_to_le32(nic->cbs_dma_addr + | 1839 | cb->link = cpu_to_le32(nic->cbs_dma_addr + |
| 1839 | ((i+1) % count) * sizeof(struct cb)); | 1840 | ((i+1) % count) * sizeof(struct cb)); |
| 1840 | cb->skb = NULL; | ||
| 1841 | } | 1841 | } |
| 1842 | 1842 | ||
| 1843 | nic->cb_to_use = nic->cb_to_send = nic->cb_to_clean = nic->cbs; | 1843 | nic->cb_to_use = nic->cb_to_send = nic->cb_to_clean = nic->cbs; |
diff --git a/drivers/net/e1000e/82571.c b/drivers/net/e1000e/82571.c index c1a42cfc80ba..b979464091bb 100644 --- a/drivers/net/e1000e/82571.c +++ b/drivers/net/e1000e/82571.c | |||
| @@ -1290,7 +1290,6 @@ static s32 e1000_setup_link_82571(struct e1000_hw *hw) | |||
| 1290 | static s32 e1000_setup_copper_link_82571(struct e1000_hw *hw) | 1290 | static s32 e1000_setup_copper_link_82571(struct e1000_hw *hw) |
| 1291 | { | 1291 | { |
| 1292 | u32 ctrl; | 1292 | u32 ctrl; |
| 1293 | u32 led_ctrl; | ||
| 1294 | s32 ret_val; | 1293 | s32 ret_val; |
| 1295 | 1294 | ||
| 1296 | ctrl = er32(CTRL); | 1295 | ctrl = er32(CTRL); |
| @@ -1305,11 +1304,6 @@ static s32 e1000_setup_copper_link_82571(struct e1000_hw *hw) | |||
| 1305 | break; | 1304 | break; |
| 1306 | case e1000_phy_igp_2: | 1305 | case e1000_phy_igp_2: |
| 1307 | ret_val = e1000e_copper_link_setup_igp(hw); | 1306 | ret_val = e1000e_copper_link_setup_igp(hw); |
| 1308 | /* Setup activity LED */ | ||
| 1309 | led_ctrl = er32(LEDCTL); | ||
| 1310 | led_ctrl &= IGP_ACTIVITY_LED_MASK; | ||
| 1311 | led_ctrl |= (IGP_ACTIVITY_LED_ENABLE | IGP_LED3_MODE); | ||
| 1312 | ew32(LEDCTL, led_ctrl); | ||
| 1313 | break; | 1307 | break; |
| 1314 | default: | 1308 | default: |
| 1315 | return -E1000_ERR_PHY; | 1309 | return -E1000_ERR_PHY; |
diff --git a/drivers/net/gianfar.c b/drivers/net/gianfar.c index 6850dc0a7b91..e0620d084644 100644 --- a/drivers/net/gianfar.c +++ b/drivers/net/gianfar.c | |||
| @@ -357,8 +357,11 @@ static void gfar_init_mac(struct net_device *ndev) | |||
| 357 | /* Configure the coalescing support */ | 357 | /* Configure the coalescing support */ |
| 358 | gfar_configure_coalescing(priv, 0xFF, 0xFF); | 358 | gfar_configure_coalescing(priv, 0xFF, 0xFF); |
| 359 | 359 | ||
| 360 | if (priv->rx_filer_enable) | 360 | if (priv->rx_filer_enable) { |
| 361 | rctrl |= RCTRL_FILREN; | 361 | rctrl |= RCTRL_FILREN; |
| 362 | /* Program the RIR0 reg with the required distribution */ | ||
| 363 | gfar_write(®s->rir0, DEFAULT_RIR0); | ||
| 364 | } | ||
| 362 | 365 | ||
| 363 | if (priv->rx_csum_enable) | 366 | if (priv->rx_csum_enable) |
| 364 | rctrl |= RCTRL_CHECKSUMMING; | 367 | rctrl |= RCTRL_CHECKSUMMING; |
| @@ -414,6 +417,36 @@ static void gfar_init_mac(struct net_device *ndev) | |||
| 414 | gfar_write(®s->fifo_tx_starve_shutoff, priv->fifo_starve_off); | 417 | gfar_write(®s->fifo_tx_starve_shutoff, priv->fifo_starve_off); |
| 415 | } | 418 | } |
| 416 | 419 | ||
| 420 | static struct net_device_stats *gfar_get_stats(struct net_device *dev) | ||
| 421 | { | ||
| 422 | struct gfar_private *priv = netdev_priv(dev); | ||
| 423 | struct netdev_queue *txq; | ||
| 424 | unsigned long rx_packets = 0, rx_bytes = 0, rx_dropped = 0; | ||
| 425 | unsigned long tx_packets = 0, tx_bytes = 0; | ||
| 426 | int i = 0; | ||
| 427 | |||
| 428 | for (i = 0; i < priv->num_rx_queues; i++) { | ||
| 429 | rx_packets += priv->rx_queue[i]->stats.rx_packets; | ||
| 430 | rx_bytes += priv->rx_queue[i]->stats.rx_bytes; | ||
| 431 | rx_dropped += priv->rx_queue[i]->stats.rx_dropped; | ||
| 432 | } | ||
| 433 | |||
| 434 | dev->stats.rx_packets = rx_packets; | ||
| 435 | dev->stats.rx_bytes = rx_bytes; | ||
| 436 | dev->stats.rx_dropped = rx_dropped; | ||
| 437 | |||
| 438 | for (i = 0; i < priv->num_tx_queues; i++) { | ||
| 439 | txq = netdev_get_tx_queue(dev, i); | ||
| 440 | tx_bytes += txq->tx_bytes; | ||
| 441 | tx_packets += txq->tx_packets; | ||
| 442 | } | ||
| 443 | |||
| 444 | dev->stats.tx_bytes = tx_bytes; | ||
| 445 | dev->stats.tx_packets = tx_packets; | ||
| 446 | |||
| 447 | return &dev->stats; | ||
| 448 | } | ||
| 449 | |||
| 417 | static const struct net_device_ops gfar_netdev_ops = { | 450 | static const struct net_device_ops gfar_netdev_ops = { |
| 418 | .ndo_open = gfar_enet_open, | 451 | .ndo_open = gfar_enet_open, |
| 419 | .ndo_start_xmit = gfar_start_xmit, | 452 | .ndo_start_xmit = gfar_start_xmit, |
| @@ -423,6 +456,7 @@ static const struct net_device_ops gfar_netdev_ops = { | |||
| 423 | .ndo_tx_timeout = gfar_timeout, | 456 | .ndo_tx_timeout = gfar_timeout, |
| 424 | .ndo_do_ioctl = gfar_ioctl, | 457 | .ndo_do_ioctl = gfar_ioctl, |
| 425 | .ndo_select_queue = gfar_select_queue, | 458 | .ndo_select_queue = gfar_select_queue, |
| 459 | .ndo_get_stats = gfar_get_stats, | ||
| 426 | .ndo_vlan_rx_register = gfar_vlan_rx_register, | 460 | .ndo_vlan_rx_register = gfar_vlan_rx_register, |
| 427 | .ndo_set_mac_address = eth_mac_addr, | 461 | .ndo_set_mac_address = eth_mac_addr, |
| 428 | .ndo_validate_addr = eth_validate_addr, | 462 | .ndo_validate_addr = eth_validate_addr, |
| @@ -1022,6 +1056,9 @@ static int gfar_probe(struct of_device *ofdev, | |||
| 1022 | priv->rx_queue[i]->rxic = DEFAULT_RXIC; | 1056 | priv->rx_queue[i]->rxic = DEFAULT_RXIC; |
| 1023 | } | 1057 | } |
| 1024 | 1058 | ||
| 1059 | /* enable filer if using multiple RX queues*/ | ||
| 1060 | if(priv->num_rx_queues > 1) | ||
| 1061 | priv->rx_filer_enable = 1; | ||
| 1025 | /* Enable most messages by default */ | 1062 | /* Enable most messages by default */ |
| 1026 | priv->msg_enable = (NETIF_MSG_IFUP << 1 ) - 1; | 1063 | priv->msg_enable = (NETIF_MSG_IFUP << 1 ) - 1; |
| 1027 | 1064 | ||
| @@ -1937,7 +1974,8 @@ static int gfar_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 1937 | } | 1974 | } |
| 1938 | 1975 | ||
| 1939 | /* Update transmit stats */ | 1976 | /* Update transmit stats */ |
| 1940 | dev->stats.tx_bytes += skb->len; | 1977 | txq->tx_bytes += skb->len; |
| 1978 | txq->tx_packets ++; | ||
| 1941 | 1979 | ||
| 1942 | txbdp = txbdp_start = tx_queue->cur_tx; | 1980 | txbdp = txbdp_start = tx_queue->cur_tx; |
| 1943 | 1981 | ||
| @@ -2295,8 +2333,6 @@ static int gfar_clean_tx_ring(struct gfar_priv_tx_q *tx_queue) | |||
| 2295 | tx_queue->skb_dirtytx = skb_dirtytx; | 2333 | tx_queue->skb_dirtytx = skb_dirtytx; |
| 2296 | tx_queue->dirty_tx = bdp; | 2334 | tx_queue->dirty_tx = bdp; |
| 2297 | 2335 | ||
| 2298 | dev->stats.tx_packets += howmany; | ||
| 2299 | |||
| 2300 | return howmany; | 2336 | return howmany; |
| 2301 | } | 2337 | } |
| 2302 | 2338 | ||
| @@ -2510,14 +2546,14 @@ int gfar_clean_rx_ring(struct gfar_priv_rx_q *rx_queue, int rx_work_limit) | |||
| 2510 | } | 2546 | } |
| 2511 | } else { | 2547 | } else { |
| 2512 | /* Increment the number of packets */ | 2548 | /* Increment the number of packets */ |
| 2513 | dev->stats.rx_packets++; | 2549 | rx_queue->stats.rx_packets++; |
| 2514 | howmany++; | 2550 | howmany++; |
| 2515 | 2551 | ||
| 2516 | if (likely(skb)) { | 2552 | if (likely(skb)) { |
| 2517 | pkt_len = bdp->length - ETH_FCS_LEN; | 2553 | pkt_len = bdp->length - ETH_FCS_LEN; |
| 2518 | /* Remove the FCS from the packet length */ | 2554 | /* Remove the FCS from the packet length */ |
| 2519 | skb_put(skb, pkt_len); | 2555 | skb_put(skb, pkt_len); |
| 2520 | dev->stats.rx_bytes += pkt_len; | 2556 | rx_queue->stats.rx_bytes += pkt_len; |
| 2521 | 2557 | ||
| 2522 | gfar_process_frame(dev, skb, amount_pull); | 2558 | gfar_process_frame(dev, skb, amount_pull); |
| 2523 | 2559 | ||
| @@ -2525,7 +2561,7 @@ int gfar_clean_rx_ring(struct gfar_priv_rx_q *rx_queue, int rx_work_limit) | |||
| 2525 | if (netif_msg_rx_err(priv)) | 2561 | if (netif_msg_rx_err(priv)) |
| 2526 | printk(KERN_WARNING | 2562 | printk(KERN_WARNING |
| 2527 | "%s: Missing skb!\n", dev->name); | 2563 | "%s: Missing skb!\n", dev->name); |
| 2528 | dev->stats.rx_dropped++; | 2564 | rx_queue->stats.rx_dropped++; |
| 2529 | priv->extra_stats.rx_skbmissing++; | 2565 | priv->extra_stats.rx_skbmissing++; |
| 2530 | } | 2566 | } |
| 2531 | 2567 | ||
diff --git a/drivers/net/gianfar.h b/drivers/net/gianfar.h index cbb451011cb5..3d72dc43dca5 100644 --- a/drivers/net/gianfar.h +++ b/drivers/net/gianfar.h | |||
| @@ -333,7 +333,7 @@ extern const char gfar_driver_version[]; | |||
| 333 | #define IMASK_BSY 0x20000000 | 333 | #define IMASK_BSY 0x20000000 |
| 334 | #define IMASK_EBERR 0x10000000 | 334 | #define IMASK_EBERR 0x10000000 |
| 335 | #define IMASK_MSRO 0x04000000 | 335 | #define IMASK_MSRO 0x04000000 |
| 336 | #define IMASK_GRSC 0x02000000 | 336 | #define IMASK_GTSC 0x02000000 |
| 337 | #define IMASK_BABT 0x01000000 | 337 | #define IMASK_BABT 0x01000000 |
| 338 | #define IMASK_TXC 0x00800000 | 338 | #define IMASK_TXC 0x00800000 |
| 339 | #define IMASK_TXEEN 0x00400000 | 339 | #define IMASK_TXEEN 0x00400000 |
| @@ -344,7 +344,7 @@ extern const char gfar_driver_version[]; | |||
| 344 | #define IMASK_XFUN 0x00010000 | 344 | #define IMASK_XFUN 0x00010000 |
| 345 | #define IMASK_RXB0 0x00008000 | 345 | #define IMASK_RXB0 0x00008000 |
| 346 | #define IMASK_MAG 0x00000800 | 346 | #define IMASK_MAG 0x00000800 |
| 347 | #define IMASK_GTSC 0x00000100 | 347 | #define IMASK_GRSC 0x00000100 |
| 348 | #define IMASK_RXFEN0 0x00000080 | 348 | #define IMASK_RXFEN0 0x00000080 |
| 349 | #define IMASK_FIR 0x00000008 | 349 | #define IMASK_FIR 0x00000008 |
| 350 | #define IMASK_FIQ 0x00000004 | 350 | #define IMASK_FIQ 0x00000004 |
| @@ -401,6 +401,10 @@ extern const char gfar_driver_version[]; | |||
| 401 | #define FPR_FILER_MASK 0xFFFFFFFF | 401 | #define FPR_FILER_MASK 0xFFFFFFFF |
| 402 | #define MAX_FILER_IDX 0xFF | 402 | #define MAX_FILER_IDX 0xFF |
| 403 | 403 | ||
| 404 | /* This default RIR value directly corresponds | ||
| 405 | * to the 3-bit hash value generated */ | ||
| 406 | #define DEFAULT_RIR0 0x05397700 | ||
| 407 | |||
| 404 | /* RQFCR register bits */ | 408 | /* RQFCR register bits */ |
| 405 | #define RQFCR_GPI 0x80000000 | 409 | #define RQFCR_GPI 0x80000000 |
| 406 | #define RQFCR_HASHTBL_Q 0x00000000 | 410 | #define RQFCR_HASHTBL_Q 0x00000000 |
| @@ -936,6 +940,15 @@ struct gfar_priv_tx_q { | |||
| 936 | unsigned short txtime; | 940 | unsigned short txtime; |
| 937 | }; | 941 | }; |
| 938 | 942 | ||
| 943 | /* | ||
| 944 | * Per RX queue stats | ||
| 945 | */ | ||
| 946 | struct rx_q_stats { | ||
| 947 | unsigned long rx_packets; | ||
| 948 | unsigned long rx_bytes; | ||
| 949 | unsigned long rx_dropped; | ||
| 950 | }; | ||
| 951 | |||
| 939 | /** | 952 | /** |
| 940 | * struct gfar_priv_rx_q - per rx queue structure | 953 | * struct gfar_priv_rx_q - per rx queue structure |
| 941 | * @rxlock: per queue rx spin lock | 954 | * @rxlock: per queue rx spin lock |
| @@ -958,6 +971,7 @@ struct gfar_priv_rx_q { | |||
| 958 | struct rxbd8 *cur_rx; | 971 | struct rxbd8 *cur_rx; |
| 959 | struct net_device *dev; | 972 | struct net_device *dev; |
| 960 | struct gfar_priv_grp *grp; | 973 | struct gfar_priv_grp *grp; |
| 974 | struct rx_q_stats stats; | ||
| 961 | u16 skb_currx; | 975 | u16 skb_currx; |
| 962 | u16 qindex; | 976 | u16 qindex; |
| 963 | unsigned int rx_ring_size; | 977 | unsigned int rx_ring_size; |
diff --git a/drivers/net/netxen/netxen_nic_main.c b/drivers/net/netxen/netxen_nic_main.c index f4996846a234..6cae26a5bd67 100644 --- a/drivers/net/netxen/netxen_nic_main.c +++ b/drivers/net/netxen/netxen_nic_main.c | |||
| @@ -57,7 +57,9 @@ static int use_msi = 1; | |||
| 57 | 57 | ||
| 58 | static int use_msi_x = 1; | 58 | static int use_msi_x = 1; |
| 59 | 59 | ||
| 60 | static unsigned long auto_fw_reset = AUTO_FW_RESET_ENABLED; | 60 | static int auto_fw_reset = AUTO_FW_RESET_ENABLED; |
| 61 | module_param(auto_fw_reset, int, 0644); | ||
| 62 | MODULE_PARM_DESC(auto_fw_reset,"Auto firmware reset (0=disabled, 1=enabled"); | ||
| 61 | 63 | ||
| 62 | static int __devinit netxen_nic_probe(struct pci_dev *pdev, | 64 | static int __devinit netxen_nic_probe(struct pci_dev *pdev, |
| 63 | const struct pci_device_id *ent); | 65 | const struct pci_device_id *ent); |
| @@ -2534,42 +2536,6 @@ static struct bin_attribute bin_attr_mem = { | |||
| 2534 | .write = netxen_sysfs_write_mem, | 2536 | .write = netxen_sysfs_write_mem, |
| 2535 | }; | 2537 | }; |
| 2536 | 2538 | ||
| 2537 | #ifdef CONFIG_MODULES | ||
| 2538 | static ssize_t | ||
| 2539 | netxen_store_auto_fw_reset(struct module_attribute *mattr, | ||
| 2540 | struct module *mod, const char *buf, size_t count) | ||
| 2541 | |||
| 2542 | { | ||
| 2543 | unsigned long new; | ||
| 2544 | |||
| 2545 | if (strict_strtoul(buf, 16, &new)) | ||
| 2546 | return -EINVAL; | ||
| 2547 | |||
| 2548 | if ((new == AUTO_FW_RESET_ENABLED) || (new == AUTO_FW_RESET_DISABLED)) { | ||
| 2549 | auto_fw_reset = new; | ||
| 2550 | return count; | ||
| 2551 | } | ||
| 2552 | |||
| 2553 | return -EINVAL; | ||
| 2554 | } | ||
| 2555 | |||
| 2556 | static ssize_t | ||
| 2557 | netxen_show_auto_fw_reset(struct module_attribute *mattr, | ||
| 2558 | struct module *mod, char *buf) | ||
| 2559 | |||
| 2560 | { | ||
| 2561 | if (auto_fw_reset == AUTO_FW_RESET_ENABLED) | ||
| 2562 | return sprintf(buf, "enabled\n"); | ||
| 2563 | else | ||
| 2564 | return sprintf(buf, "disabled\n"); | ||
| 2565 | } | ||
| 2566 | |||
| 2567 | static struct module_attribute mod_attr_fw_reset = { | ||
| 2568 | .attr = {.name = "auto_fw_reset", .mode = (S_IRUGO | S_IWUSR)}, | ||
| 2569 | .show = netxen_show_auto_fw_reset, | ||
| 2570 | .store = netxen_store_auto_fw_reset, | ||
| 2571 | }; | ||
| 2572 | #endif | ||
| 2573 | 2539 | ||
| 2574 | static void | 2540 | static void |
| 2575 | netxen_create_sysfs_entries(struct netxen_adapter *adapter) | 2541 | netxen_create_sysfs_entries(struct netxen_adapter *adapter) |
| @@ -2775,23 +2741,12 @@ static struct pci_driver netxen_driver = { | |||
| 2775 | 2741 | ||
| 2776 | static int __init netxen_init_module(void) | 2742 | static int __init netxen_init_module(void) |
| 2777 | { | 2743 | { |
| 2778 | #ifdef CONFIG_MODULES | ||
| 2779 | struct module *mod = THIS_MODULE; | ||
| 2780 | #endif | ||
| 2781 | |||
| 2782 | printk(KERN_INFO "%s\n", netxen_nic_driver_string); | 2744 | printk(KERN_INFO "%s\n", netxen_nic_driver_string); |
| 2783 | 2745 | ||
| 2784 | #ifdef CONFIG_INET | 2746 | #ifdef CONFIG_INET |
| 2785 | register_netdevice_notifier(&netxen_netdev_cb); | 2747 | register_netdevice_notifier(&netxen_netdev_cb); |
| 2786 | register_inetaddr_notifier(&netxen_inetaddr_cb); | 2748 | register_inetaddr_notifier(&netxen_inetaddr_cb); |
| 2787 | #endif | 2749 | #endif |
| 2788 | |||
| 2789 | #ifdef CONFIG_MODULES | ||
| 2790 | if (sysfs_create_file(&mod->mkobj.kobj, &mod_attr_fw_reset.attr)) | ||
| 2791 | printk(KERN_ERR "%s: Failed to create auto_fw_reset " | ||
| 2792 | "sysfs entry.", netxen_nic_driver_name); | ||
| 2793 | #endif | ||
| 2794 | |||
| 2795 | return pci_register_driver(&netxen_driver); | 2750 | return pci_register_driver(&netxen_driver); |
| 2796 | } | 2751 | } |
| 2797 | 2752 | ||
| @@ -2799,12 +2754,6 @@ module_init(netxen_init_module); | |||
| 2799 | 2754 | ||
| 2800 | static void __exit netxen_exit_module(void) | 2755 | static void __exit netxen_exit_module(void) |
| 2801 | { | 2756 | { |
| 2802 | #ifdef CONFIG_MODULES | ||
| 2803 | struct module *mod = THIS_MODULE; | ||
| 2804 | |||
| 2805 | sysfs_remove_file(&mod->mkobj.kobj, &mod_attr_fw_reset.attr); | ||
| 2806 | #endif | ||
| 2807 | |||
| 2808 | pci_unregister_driver(&netxen_driver); | 2757 | pci_unregister_driver(&netxen_driver); |
| 2809 | 2758 | ||
| 2810 | #ifdef CONFIG_INET | 2759 | #ifdef CONFIG_INET |
diff --git a/drivers/net/phy/broadcom.c b/drivers/net/phy/broadcom.c index f63c96a4ecb4..c13cf64095b6 100644 --- a/drivers/net/phy/broadcom.c +++ b/drivers/net/phy/broadcom.c | |||
| @@ -326,7 +326,8 @@ error: | |||
| 326 | 326 | ||
| 327 | static void bcm54xx_adjust_rxrefclk(struct phy_device *phydev) | 327 | static void bcm54xx_adjust_rxrefclk(struct phy_device *phydev) |
| 328 | { | 328 | { |
| 329 | u32 val, orig; | 329 | u32 orig; |
| 330 | int val; | ||
| 330 | bool clk125en = true; | 331 | bool clk125en = true; |
| 331 | 332 | ||
| 332 | /* Abort if we are using an untested phy. */ | 333 | /* Abort if we are using an untested phy. */ |
diff --git a/fs/nfsd/nfsfh.c b/fs/nfsd/nfsfh.c index 1c12177b908c..55c8e63af0be 100644 --- a/fs/nfsd/nfsfh.c +++ b/fs/nfsd/nfsfh.c | |||
| @@ -89,7 +89,7 @@ static __be32 nfsd_setuser_and_check_port(struct svc_rqst *rqstp, | |||
| 89 | int flags = nfsexp_flags(rqstp, exp); | 89 | int flags = nfsexp_flags(rqstp, exp); |
| 90 | 90 | ||
| 91 | /* Check if the request originated from a secure port. */ | 91 | /* Check if the request originated from a secure port. */ |
| 92 | if (!rqstp->rq_secure && (flags & NFSEXP_INSECURE_PORT)) { | 92 | if (!rqstp->rq_secure && !(flags & NFSEXP_INSECURE_PORT)) { |
| 93 | RPC_IFDEBUG(char buf[RPC_MAX_ADDRBUFLEN]); | 93 | RPC_IFDEBUG(char buf[RPC_MAX_ADDRBUFLEN]); |
| 94 | dprintk(KERN_WARNING | 94 | dprintk(KERN_WARNING |
| 95 | "nfsd: request from insecure port %s!\n", | 95 | "nfsd: request from insecure port %s!\n", |
diff --git a/kernel/sched.c b/kernel/sched.c index 720df108a2d6..87f1f47beffe 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
| @@ -26,8 +26,6 @@ | |||
| 26 | * Thomas Gleixner, Mike Kravetz | 26 | * Thomas Gleixner, Mike Kravetz |
| 27 | */ | 27 | */ |
| 28 | 28 | ||
| 29 | #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt | ||
| 30 | |||
| 31 | #include <linux/mm.h> | 29 | #include <linux/mm.h> |
| 32 | #include <linux/module.h> | 30 | #include <linux/module.h> |
| 33 | #include <linux/nmi.h> | 31 | #include <linux/nmi.h> |
| @@ -2348,7 +2346,7 @@ int select_task_rq(struct task_struct *p, int sd_flags, int wake_flags) | |||
| 2348 | * not worry about this generic constraint ] | 2346 | * not worry about this generic constraint ] |
| 2349 | */ | 2347 | */ |
| 2350 | if (unlikely(!cpumask_test_cpu(cpu, &p->cpus_allowed) || | 2348 | if (unlikely(!cpumask_test_cpu(cpu, &p->cpus_allowed) || |
| 2351 | !cpu_active(cpu))) | 2349 | !cpu_online(cpu))) |
| 2352 | cpu = select_fallback_rq(task_cpu(p), p); | 2350 | cpu = select_fallback_rq(task_cpu(p), p); |
| 2353 | 2351 | ||
| 2354 | return cpu; | 2352 | return cpu; |
| @@ -5375,8 +5373,8 @@ static noinline void __schedule_bug(struct task_struct *prev) | |||
| 5375 | { | 5373 | { |
| 5376 | struct pt_regs *regs = get_irq_regs(); | 5374 | struct pt_regs *regs = get_irq_regs(); |
| 5377 | 5375 | ||
| 5378 | pr_err("BUG: scheduling while atomic: %s/%d/0x%08x\n", | 5376 | printk(KERN_ERR "BUG: scheduling while atomic: %s/%d/0x%08x\n", |
| 5379 | prev->comm, prev->pid, preempt_count()); | 5377 | prev->comm, prev->pid, preempt_count()); |
| 5380 | 5378 | ||
| 5381 | debug_show_held_locks(prev); | 5379 | debug_show_held_locks(prev); |
| 5382 | print_modules(); | 5380 | print_modules(); |
| @@ -6940,23 +6938,23 @@ void sched_show_task(struct task_struct *p) | |||
| 6940 | unsigned state; | 6938 | unsigned state; |
| 6941 | 6939 | ||
| 6942 | state = p->state ? __ffs(p->state) + 1 : 0; | 6940 | state = p->state ? __ffs(p->state) + 1 : 0; |
| 6943 | pr_info("%-13.13s %c", p->comm, | 6941 | printk(KERN_INFO "%-13.13s %c", p->comm, |
| 6944 | state < sizeof(stat_nam) - 1 ? stat_nam[state] : '?'); | 6942 | state < sizeof(stat_nam) - 1 ? stat_nam[state] : '?'); |
| 6945 | #if BITS_PER_LONG == 32 | 6943 | #if BITS_PER_LONG == 32 |
| 6946 | if (state == TASK_RUNNING) | 6944 | if (state == TASK_RUNNING) |
| 6947 | pr_cont(" running "); | 6945 | printk(KERN_CONT " running "); |
| 6948 | else | 6946 | else |
| 6949 | pr_cont(" %08lx ", thread_saved_pc(p)); | 6947 | printk(KERN_CONT " %08lx ", thread_saved_pc(p)); |
| 6950 | #else | 6948 | #else |
| 6951 | if (state == TASK_RUNNING) | 6949 | if (state == TASK_RUNNING) |
| 6952 | pr_cont(" running task "); | 6950 | printk(KERN_CONT " running task "); |
| 6953 | else | 6951 | else |
| 6954 | pr_cont(" %016lx ", thread_saved_pc(p)); | 6952 | printk(KERN_CONT " %016lx ", thread_saved_pc(p)); |
| 6955 | #endif | 6953 | #endif |
| 6956 | #ifdef CONFIG_DEBUG_STACK_USAGE | 6954 | #ifdef CONFIG_DEBUG_STACK_USAGE |
| 6957 | free = stack_not_used(p); | 6955 | free = stack_not_used(p); |
| 6958 | #endif | 6956 | #endif |
| 6959 | pr_cont("%5lu %5d %6d 0x%08lx\n", free, | 6957 | printk(KERN_CONT "%5lu %5d %6d 0x%08lx\n", free, |
| 6960 | task_pid_nr(p), task_pid_nr(p->real_parent), | 6958 | task_pid_nr(p), task_pid_nr(p->real_parent), |
| 6961 | (unsigned long)task_thread_info(p)->flags); | 6959 | (unsigned long)task_thread_info(p)->flags); |
| 6962 | 6960 | ||
| @@ -6968,9 +6966,11 @@ void show_state_filter(unsigned long state_filter) | |||
| 6968 | struct task_struct *g, *p; | 6966 | struct task_struct *g, *p; |
| 6969 | 6967 | ||
| 6970 | #if BITS_PER_LONG == 32 | 6968 | #if BITS_PER_LONG == 32 |
| 6971 | pr_info(" task PC stack pid father\n"); | 6969 | printk(KERN_INFO |
| 6970 | " task PC stack pid father\n"); | ||
| 6972 | #else | 6971 | #else |
| 6973 | pr_info(" task PC stack pid father\n"); | 6972 | printk(KERN_INFO |
| 6973 | " task PC stack pid father\n"); | ||
| 6974 | #endif | 6974 | #endif |
| 6975 | read_lock(&tasklist_lock); | 6975 | read_lock(&tasklist_lock); |
| 6976 | do_each_thread(g, p) { | 6976 | do_each_thread(g, p) { |
| @@ -7828,44 +7828,48 @@ static int sched_domain_debug_one(struct sched_domain *sd, int cpu, int level, | |||
| 7828 | printk(KERN_DEBUG "%*s domain %d: ", level, "", level); | 7828 | printk(KERN_DEBUG "%*s domain %d: ", level, "", level); |
| 7829 | 7829 | ||
| 7830 | if (!(sd->flags & SD_LOAD_BALANCE)) { | 7830 | if (!(sd->flags & SD_LOAD_BALANCE)) { |
| 7831 | pr_cont("does not load-balance\n"); | 7831 | printk("does not load-balance\n"); |
| 7832 | if (sd->parent) | 7832 | if (sd->parent) |
| 7833 | pr_err("ERROR: !SD_LOAD_BALANCE domain has parent\n"); | 7833 | printk(KERN_ERR "ERROR: !SD_LOAD_BALANCE domain" |
| 7834 | " has parent"); | ||
| 7834 | return -1; | 7835 | return -1; |
| 7835 | } | 7836 | } |
| 7836 | 7837 | ||
| 7837 | pr_cont("span %s level %s\n", str, sd->name); | 7838 | printk(KERN_CONT "span %s level %s\n", str, sd->name); |
| 7838 | 7839 | ||
| 7839 | if (!cpumask_test_cpu(cpu, sched_domain_span(sd))) { | 7840 | if (!cpumask_test_cpu(cpu, sched_domain_span(sd))) { |
| 7840 | pr_err("ERROR: domain->span does not contain CPU%d\n", cpu); | 7841 | printk(KERN_ERR "ERROR: domain->span does not contain " |
| 7842 | "CPU%d\n", cpu); | ||
| 7841 | } | 7843 | } |
| 7842 | if (!cpumask_test_cpu(cpu, sched_group_cpus(group))) { | 7844 | if (!cpumask_test_cpu(cpu, sched_group_cpus(group))) { |
| 7843 | pr_err("ERROR: domain->groups does not contain CPU%d\n", cpu); | 7845 | printk(KERN_ERR "ERROR: domain->groups does not contain" |
| 7846 | " CPU%d\n", cpu); | ||
| 7844 | } | 7847 | } |
| 7845 | 7848 | ||
| 7846 | printk(KERN_DEBUG "%*s groups:", level + 1, ""); | 7849 | printk(KERN_DEBUG "%*s groups:", level + 1, ""); |
| 7847 | do { | 7850 | do { |
| 7848 | if (!group) { | 7851 | if (!group) { |
| 7849 | pr_cont("\n"); | 7852 | printk("\n"); |
| 7850 | pr_err("ERROR: group is NULL\n"); | 7853 | printk(KERN_ERR "ERROR: group is NULL\n"); |
| 7851 | break; | 7854 | break; |
| 7852 | } | 7855 | } |
| 7853 | 7856 | ||
| 7854 | if (!group->cpu_power) { | 7857 | if (!group->cpu_power) { |
| 7855 | pr_cont("\n"); | 7858 | printk(KERN_CONT "\n"); |
| 7856 | pr_err("ERROR: domain->cpu_power not set\n"); | 7859 | printk(KERN_ERR "ERROR: domain->cpu_power not " |
| 7860 | "set\n"); | ||
| 7857 | break; | 7861 | break; |
| 7858 | } | 7862 | } |
| 7859 | 7863 | ||
| 7860 | if (!cpumask_weight(sched_group_cpus(group))) { | 7864 | if (!cpumask_weight(sched_group_cpus(group))) { |
| 7861 | pr_cont("\n"); | 7865 | printk(KERN_CONT "\n"); |
| 7862 | pr_err("ERROR: empty group\n"); | 7866 | printk(KERN_ERR "ERROR: empty group\n"); |
| 7863 | break; | 7867 | break; |
| 7864 | } | 7868 | } |
| 7865 | 7869 | ||
| 7866 | if (cpumask_intersects(groupmask, sched_group_cpus(group))) { | 7870 | if (cpumask_intersects(groupmask, sched_group_cpus(group))) { |
| 7867 | pr_cont("\n"); | 7871 | printk(KERN_CONT "\n"); |
| 7868 | pr_err("ERROR: repeated CPUs\n"); | 7872 | printk(KERN_ERR "ERROR: repeated CPUs\n"); |
| 7869 | break; | 7873 | break; |
| 7870 | } | 7874 | } |
| 7871 | 7875 | ||
| @@ -7873,21 +7877,23 @@ static int sched_domain_debug_one(struct sched_domain *sd, int cpu, int level, | |||
| 7873 | 7877 | ||
| 7874 | cpulist_scnprintf(str, sizeof(str), sched_group_cpus(group)); | 7878 | cpulist_scnprintf(str, sizeof(str), sched_group_cpus(group)); |
| 7875 | 7879 | ||
| 7876 | pr_cont(" %s", str); | 7880 | printk(KERN_CONT " %s", str); |
| 7877 | if (group->cpu_power != SCHED_LOAD_SCALE) { | 7881 | if (group->cpu_power != SCHED_LOAD_SCALE) { |
| 7878 | pr_cont(" (cpu_power = %d)", group->cpu_power); | 7882 | printk(KERN_CONT " (cpu_power = %d)", |
| 7883 | group->cpu_power); | ||
| 7879 | } | 7884 | } |
| 7880 | 7885 | ||
| 7881 | group = group->next; | 7886 | group = group->next; |
| 7882 | } while (group != sd->groups); | 7887 | } while (group != sd->groups); |
| 7883 | pr_cont("\n"); | 7888 | printk(KERN_CONT "\n"); |
| 7884 | 7889 | ||
| 7885 | if (!cpumask_equal(sched_domain_span(sd), groupmask)) | 7890 | if (!cpumask_equal(sched_domain_span(sd), groupmask)) |
| 7886 | pr_err("ERROR: groups don't span domain->span\n"); | 7891 | printk(KERN_ERR "ERROR: groups don't span domain->span\n"); |
| 7887 | 7892 | ||
| 7888 | if (sd->parent && | 7893 | if (sd->parent && |
| 7889 | !cpumask_subset(groupmask, sched_domain_span(sd->parent))) | 7894 | !cpumask_subset(groupmask, sched_domain_span(sd->parent))) |
| 7890 | pr_err("ERROR: parent span is not a superset of domain->span\n"); | 7895 | printk(KERN_ERR "ERROR: parent span is not a superset " |
| 7896 | "of domain->span\n"); | ||
| 7891 | return 0; | 7897 | return 0; |
| 7892 | } | 7898 | } |
| 7893 | 7899 | ||
| @@ -8443,7 +8449,8 @@ static int build_numa_sched_groups(struct s_data *d, | |||
| 8443 | sg = kmalloc_node(sizeof(struct sched_group) + cpumask_size(), | 8449 | sg = kmalloc_node(sizeof(struct sched_group) + cpumask_size(), |
| 8444 | GFP_KERNEL, num); | 8450 | GFP_KERNEL, num); |
| 8445 | if (!sg) { | 8451 | if (!sg) { |
| 8446 | pr_warning("Can not alloc domain group for node %d\n", num); | 8452 | printk(KERN_WARNING "Can not alloc domain group for node %d\n", |
| 8453 | num); | ||
| 8447 | return -ENOMEM; | 8454 | return -ENOMEM; |
| 8448 | } | 8455 | } |
| 8449 | d->sched_group_nodes[num] = sg; | 8456 | d->sched_group_nodes[num] = sg; |
| @@ -8472,8 +8479,8 @@ static int build_numa_sched_groups(struct s_data *d, | |||
| 8472 | sg = kmalloc_node(sizeof(struct sched_group) + cpumask_size(), | 8479 | sg = kmalloc_node(sizeof(struct sched_group) + cpumask_size(), |
| 8473 | GFP_KERNEL, num); | 8480 | GFP_KERNEL, num); |
| 8474 | if (!sg) { | 8481 | if (!sg) { |
| 8475 | pr_warning("Can not alloc domain group for node %d\n", | 8482 | printk(KERN_WARNING |
| 8476 | j); | 8483 | "Can not alloc domain group for node %d\n", j); |
| 8477 | return -ENOMEM; | 8484 | return -ENOMEM; |
| 8478 | } | 8485 | } |
| 8479 | sg->cpu_power = 0; | 8486 | sg->cpu_power = 0; |
| @@ -8701,7 +8708,7 @@ static enum s_alloc __visit_domain_allocation_hell(struct s_data *d, | |||
| 8701 | d->sched_group_nodes = kcalloc(nr_node_ids, | 8708 | d->sched_group_nodes = kcalloc(nr_node_ids, |
| 8702 | sizeof(struct sched_group *), GFP_KERNEL); | 8709 | sizeof(struct sched_group *), GFP_KERNEL); |
| 8703 | if (!d->sched_group_nodes) { | 8710 | if (!d->sched_group_nodes) { |
| 8704 | pr_warning("Can not alloc sched group node list\n"); | 8711 | printk(KERN_WARNING "Can not alloc sched group node list\n"); |
| 8705 | return sa_notcovered; | 8712 | return sa_notcovered; |
| 8706 | } | 8713 | } |
| 8707 | sched_group_nodes_bycpu[cpumask_first(cpu_map)] = d->sched_group_nodes; | 8714 | sched_group_nodes_bycpu[cpumask_first(cpu_map)] = d->sched_group_nodes; |
| @@ -8718,7 +8725,7 @@ static enum s_alloc __visit_domain_allocation_hell(struct s_data *d, | |||
| 8718 | return sa_send_covered; | 8725 | return sa_send_covered; |
| 8719 | d->rd = alloc_rootdomain(); | 8726 | d->rd = alloc_rootdomain(); |
| 8720 | if (!d->rd) { | 8727 | if (!d->rd) { |
| 8721 | pr_warning("Cannot alloc root domain\n"); | 8728 | printk(KERN_WARNING "Cannot alloc root domain\n"); |
| 8722 | return sa_tmpmask; | 8729 | return sa_tmpmask; |
| 8723 | } | 8730 | } |
| 8724 | return sa_rootdomain; | 8731 | return sa_rootdomain; |
| @@ -9700,11 +9707,13 @@ void __might_sleep(char *file, int line, int preempt_offset) | |||
| 9700 | return; | 9707 | return; |
| 9701 | prev_jiffy = jiffies; | 9708 | prev_jiffy = jiffies; |
| 9702 | 9709 | ||
| 9703 | pr_err("BUG: sleeping function called from invalid context at %s:%d\n", | 9710 | printk(KERN_ERR |
| 9704 | file, line); | 9711 | "BUG: sleeping function called from invalid context at %s:%d\n", |
| 9705 | pr_err("in_atomic(): %d, irqs_disabled(): %d, pid: %d, name: %s\n", | 9712 | file, line); |
| 9706 | in_atomic(), irqs_disabled(), | 9713 | printk(KERN_ERR |
| 9707 | current->pid, current->comm); | 9714 | "in_atomic(): %d, irqs_disabled(): %d, pid: %d, name: %s\n", |
| 9715 | in_atomic(), irqs_disabled(), | ||
| 9716 | current->pid, current->comm); | ||
| 9708 | 9717 | ||
| 9709 | debug_show_held_locks(current); | 9718 | debug_show_held_locks(current); |
| 9710 | if (irqs_disabled()) | 9719 | if (irqs_disabled()) |
diff --git a/kernel/sched_idletask.c b/kernel/sched_idletask.c index 21b969a28725..5f93b570d383 100644 --- a/kernel/sched_idletask.c +++ b/kernel/sched_idletask.c | |||
| @@ -35,7 +35,7 @@ static void | |||
| 35 | dequeue_task_idle(struct rq *rq, struct task_struct *p, int sleep) | 35 | dequeue_task_idle(struct rq *rq, struct task_struct *p, int sleep) |
| 36 | { | 36 | { |
| 37 | raw_spin_unlock_irq(&rq->lock); | 37 | raw_spin_unlock_irq(&rq->lock); |
| 38 | pr_err("bad: scheduling from the idle thread!\n"); | 38 | printk(KERN_ERR "bad: scheduling from the idle thread!\n"); |
| 39 | dump_stack(); | 39 | dump_stack(); |
| 40 | raw_spin_lock_irq(&rq->lock); | 40 | raw_spin_lock_irq(&rq->lock); |
| 41 | } | 41 | } |
diff --git a/net/bluetooth/hidp/core.c b/net/bluetooth/hidp/core.c index 569750010fd3..18e7f5a43dc4 100644 --- a/net/bluetooth/hidp/core.c +++ b/net/bluetooth/hidp/core.c | |||
| @@ -770,7 +770,7 @@ static int hidp_setup_hid(struct hidp_session *session, | |||
| 770 | 770 | ||
| 771 | hid = hid_allocate_device(); | 771 | hid = hid_allocate_device(); |
| 772 | if (IS_ERR(hid)) | 772 | if (IS_ERR(hid)) |
| 773 | return PTR_ERR(session->hid); | 773 | return PTR_ERR(hid); |
| 774 | 774 | ||
| 775 | session->hid = hid; | 775 | session->hid = hid; |
| 776 | session->req = req; | 776 | session->req = req; |
diff --git a/net/bluetooth/l2cap.c b/net/bluetooth/l2cap.c index 5129b88c8e5b..1120cf14a548 100644 --- a/net/bluetooth/l2cap.c +++ b/net/bluetooth/l2cap.c | |||
| @@ -1212,6 +1212,7 @@ static void l2cap_monitor_timeout(unsigned long arg) | |||
| 1212 | bh_lock_sock(sk); | 1212 | bh_lock_sock(sk); |
| 1213 | if (l2cap_pi(sk)->retry_count >= l2cap_pi(sk)->remote_max_tx) { | 1213 | if (l2cap_pi(sk)->retry_count >= l2cap_pi(sk)->remote_max_tx) { |
| 1214 | l2cap_send_disconn_req(l2cap_pi(sk)->conn, sk); | 1214 | l2cap_send_disconn_req(l2cap_pi(sk)->conn, sk); |
| 1215 | bh_unlock_sock(sk); | ||
| 1215 | return; | 1216 | return; |
| 1216 | } | 1217 | } |
| 1217 | 1218 | ||
| @@ -3435,8 +3436,8 @@ static inline int l2cap_data_channel_sframe(struct sock *sk, u16 rx_control, str | |||
| 3435 | (pi->unacked_frames > 0)) | 3436 | (pi->unacked_frames > 0)) |
| 3436 | __mod_retrans_timer(); | 3437 | __mod_retrans_timer(); |
| 3437 | 3438 | ||
| 3438 | l2cap_ertm_send(sk); | ||
| 3439 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; | 3439 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; |
| 3440 | l2cap_ertm_send(sk); | ||
| 3440 | } | 3441 | } |
| 3441 | break; | 3442 | break; |
| 3442 | 3443 | ||
| @@ -3471,9 +3472,9 @@ static inline int l2cap_data_channel_sframe(struct sock *sk, u16 rx_control, str | |||
| 3471 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; | 3472 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; |
| 3472 | 3473 | ||
| 3473 | if (rx_control & L2CAP_CTRL_POLL) { | 3474 | if (rx_control & L2CAP_CTRL_POLL) { |
| 3474 | l2cap_retransmit_frame(sk, tx_seq); | ||
| 3475 | pi->expected_ack_seq = tx_seq; | 3475 | pi->expected_ack_seq = tx_seq; |
| 3476 | l2cap_drop_acked_frames(sk); | 3476 | l2cap_drop_acked_frames(sk); |
| 3477 | l2cap_retransmit_frame(sk, tx_seq); | ||
| 3477 | l2cap_ertm_send(sk); | 3478 | l2cap_ertm_send(sk); |
| 3478 | if (pi->conn_state & L2CAP_CONN_WAIT_F) { | 3479 | if (pi->conn_state & L2CAP_CONN_WAIT_F) { |
| 3479 | pi->srej_save_reqseq = tx_seq; | 3480 | pi->srej_save_reqseq = tx_seq; |
diff --git a/net/ipv6/reassembly.c b/net/ipv6/reassembly.c index 3b3a95607125..2cddea3bd6be 100644 --- a/net/ipv6/reassembly.c +++ b/net/ipv6/reassembly.c | |||
| @@ -708,7 +708,8 @@ static void ip6_frags_ns_sysctl_unregister(struct net *net) | |||
| 708 | 708 | ||
| 709 | table = net->ipv6.sysctl.frags_hdr->ctl_table_arg; | 709 | table = net->ipv6.sysctl.frags_hdr->ctl_table_arg; |
| 710 | unregister_net_sysctl_table(net->ipv6.sysctl.frags_hdr); | 710 | unregister_net_sysctl_table(net->ipv6.sysctl.frags_hdr); |
| 711 | kfree(table); | 711 | if (!net_eq(net, &init_net)) |
| 712 | kfree(table); | ||
| 712 | } | 713 | } |
| 713 | 714 | ||
| 714 | static struct ctl_table_header *ip6_ctl_header; | 715 | static struct ctl_table_header *ip6_ctl_header; |
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index db3b27303890..c2bd74c5f8d9 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
| @@ -2630,6 +2630,7 @@ struct ctl_table *ipv6_route_sysctl_init(struct net *net) | |||
| 2630 | table[6].data = &net->ipv6.sysctl.ip6_rt_gc_elasticity; | 2630 | table[6].data = &net->ipv6.sysctl.ip6_rt_gc_elasticity; |
| 2631 | table[7].data = &net->ipv6.sysctl.ip6_rt_mtu_expires; | 2631 | table[7].data = &net->ipv6.sysctl.ip6_rt_mtu_expires; |
| 2632 | table[8].data = &net->ipv6.sysctl.ip6_rt_min_advmss; | 2632 | table[8].data = &net->ipv6.sysctl.ip6_rt_min_advmss; |
| 2633 | table[9].data = &net->ipv6.sysctl.ip6_rt_gc_min_interval; | ||
| 2633 | } | 2634 | } |
| 2634 | 2635 | ||
| 2635 | return table; | 2636 | return table; |
diff --git a/sound/arm/aaci.c b/sound/arm/aaci.c index 1497dce1b04a..c5699863643b 100644 --- a/sound/arm/aaci.c +++ b/sound/arm/aaci.c | |||
| @@ -172,14 +172,15 @@ static unsigned short aaci_ac97_read(struct snd_ac97 *ac97, unsigned short reg) | |||
| 172 | return v; | 172 | return v; |
| 173 | } | 173 | } |
| 174 | 174 | ||
| 175 | static inline void aaci_chan_wait_ready(struct aaci_runtime *aacirun) | 175 | static inline void |
| 176 | aaci_chan_wait_ready(struct aaci_runtime *aacirun, unsigned long mask) | ||
| 176 | { | 177 | { |
| 177 | u32 val; | 178 | u32 val; |
| 178 | int timeout = 5000; | 179 | int timeout = 5000; |
| 179 | 180 | ||
| 180 | do { | 181 | do { |
| 181 | val = readl(aacirun->base + AACI_SR); | 182 | val = readl(aacirun->base + AACI_SR); |
| 182 | } while (val & (SR_TXB|SR_RXB) && timeout--); | 183 | } while (val & mask && timeout--); |
| 183 | } | 184 | } |
| 184 | 185 | ||
| 185 | 186 | ||
| @@ -208,8 +209,10 @@ static void aaci_fifo_irq(struct aaci *aaci, int channel, u32 mask) | |||
| 208 | writel(0, aacirun->base + AACI_IE); | 209 | writel(0, aacirun->base + AACI_IE); |
| 209 | return; | 210 | return; |
| 210 | } | 211 | } |
| 211 | ptr = aacirun->ptr; | ||
| 212 | 212 | ||
| 213 | spin_lock(&aacirun->lock); | ||
| 214 | |||
| 215 | ptr = aacirun->ptr; | ||
| 213 | do { | 216 | do { |
| 214 | unsigned int len = aacirun->fifosz; | 217 | unsigned int len = aacirun->fifosz; |
| 215 | u32 val; | 218 | u32 val; |
| @@ -217,9 +220,9 @@ static void aaci_fifo_irq(struct aaci *aaci, int channel, u32 mask) | |||
| 217 | if (aacirun->bytes <= 0) { | 220 | if (aacirun->bytes <= 0) { |
| 218 | aacirun->bytes += aacirun->period; | 221 | aacirun->bytes += aacirun->period; |
| 219 | aacirun->ptr = ptr; | 222 | aacirun->ptr = ptr; |
| 220 | spin_unlock(&aaci->lock); | 223 | spin_unlock(&aacirun->lock); |
| 221 | snd_pcm_period_elapsed(aacirun->substream); | 224 | snd_pcm_period_elapsed(aacirun->substream); |
| 222 | spin_lock(&aaci->lock); | 225 | spin_lock(&aacirun->lock); |
| 223 | } | 226 | } |
| 224 | if (!(aacirun->cr & CR_EN)) | 227 | if (!(aacirun->cr & CR_EN)) |
| 225 | break; | 228 | break; |
| @@ -245,7 +248,10 @@ static void aaci_fifo_irq(struct aaci *aaci, int channel, u32 mask) | |||
| 245 | ptr = aacirun->start; | 248 | ptr = aacirun->start; |
| 246 | } | 249 | } |
| 247 | } while(1); | 250 | } while(1); |
| 251 | |||
| 248 | aacirun->ptr = ptr; | 252 | aacirun->ptr = ptr; |
| 253 | |||
| 254 | spin_unlock(&aacirun->lock); | ||
| 249 | } | 255 | } |
| 250 | 256 | ||
| 251 | if (mask & ISR_URINTR) { | 257 | if (mask & ISR_URINTR) { |
| @@ -263,6 +269,8 @@ static void aaci_fifo_irq(struct aaci *aaci, int channel, u32 mask) | |||
| 263 | return; | 269 | return; |
| 264 | } | 270 | } |
| 265 | 271 | ||
| 272 | spin_lock(&aacirun->lock); | ||
| 273 | |||
| 266 | ptr = aacirun->ptr; | 274 | ptr = aacirun->ptr; |
| 267 | do { | 275 | do { |
| 268 | unsigned int len = aacirun->fifosz; | 276 | unsigned int len = aacirun->fifosz; |
| @@ -271,9 +279,9 @@ static void aaci_fifo_irq(struct aaci *aaci, int channel, u32 mask) | |||
| 271 | if (aacirun->bytes <= 0) { | 279 | if (aacirun->bytes <= 0) { |
| 272 | aacirun->bytes += aacirun->period; | 280 | aacirun->bytes += aacirun->period; |
| 273 | aacirun->ptr = ptr; | 281 | aacirun->ptr = ptr; |
| 274 | spin_unlock(&aaci->lock); | 282 | spin_unlock(&aacirun->lock); |
| 275 | snd_pcm_period_elapsed(aacirun->substream); | 283 | snd_pcm_period_elapsed(aacirun->substream); |
| 276 | spin_lock(&aaci->lock); | 284 | spin_lock(&aacirun->lock); |
| 277 | } | 285 | } |
| 278 | if (!(aacirun->cr & CR_EN)) | 286 | if (!(aacirun->cr & CR_EN)) |
| 279 | break; | 287 | break; |
| @@ -301,6 +309,8 @@ static void aaci_fifo_irq(struct aaci *aaci, int channel, u32 mask) | |||
| 301 | } while (1); | 309 | } while (1); |
| 302 | 310 | ||
| 303 | aacirun->ptr = ptr; | 311 | aacirun->ptr = ptr; |
| 312 | |||
| 313 | spin_unlock(&aacirun->lock); | ||
| 304 | } | 314 | } |
| 305 | } | 315 | } |
| 306 | 316 | ||
| @@ -310,7 +320,6 @@ static irqreturn_t aaci_irq(int irq, void *devid) | |||
| 310 | u32 mask; | 320 | u32 mask; |
| 311 | int i; | 321 | int i; |
| 312 | 322 | ||
| 313 | spin_lock(&aaci->lock); | ||
| 314 | mask = readl(aaci->base + AACI_ALLINTS); | 323 | mask = readl(aaci->base + AACI_ALLINTS); |
| 315 | if (mask) { | 324 | if (mask) { |
| 316 | u32 m = mask; | 325 | u32 m = mask; |
| @@ -320,7 +329,6 @@ static irqreturn_t aaci_irq(int irq, void *devid) | |||
| 320 | } | 329 | } |
| 321 | } | 330 | } |
| 322 | } | 331 | } |
| 323 | spin_unlock(&aaci->lock); | ||
| 324 | 332 | ||
| 325 | return mask ? IRQ_HANDLED : IRQ_NONE; | 333 | return mask ? IRQ_HANDLED : IRQ_NONE; |
| 326 | } | 334 | } |
| @@ -330,63 +338,6 @@ static irqreturn_t aaci_irq(int irq, void *devid) | |||
| 330 | /* | 338 | /* |
| 331 | * ALSA support. | 339 | * ALSA support. |
| 332 | */ | 340 | */ |
| 333 | |||
| 334 | struct aaci_stream { | ||
| 335 | unsigned char codec_idx; | ||
| 336 | unsigned char rate_idx; | ||
| 337 | }; | ||
| 338 | |||
| 339 | static struct aaci_stream aaci_streams[] = { | ||
| 340 | [ACSTREAM_FRONT] = { | ||
| 341 | .codec_idx = 0, | ||
| 342 | .rate_idx = AC97_RATES_FRONT_DAC, | ||
| 343 | }, | ||
| 344 | [ACSTREAM_SURROUND] = { | ||
| 345 | .codec_idx = 0, | ||
| 346 | .rate_idx = AC97_RATES_SURR_DAC, | ||
| 347 | }, | ||
| 348 | [ACSTREAM_LFE] = { | ||
| 349 | .codec_idx = 0, | ||
| 350 | .rate_idx = AC97_RATES_LFE_DAC, | ||
| 351 | }, | ||
| 352 | }; | ||
| 353 | |||
| 354 | static inline unsigned int aaci_rate_mask(struct aaci *aaci, int streamid) | ||
| 355 | { | ||
| 356 | struct aaci_stream *s = aaci_streams + streamid; | ||
| 357 | return aaci->ac97_bus->codec[s->codec_idx]->rates[s->rate_idx]; | ||
| 358 | } | ||
| 359 | |||
| 360 | static unsigned int rate_list[] = { | ||
| 361 | 5512, 8000, 11025, 16000, 22050, 32000, 44100, | ||
| 362 | 48000, 64000, 88200, 96000, 176400, 192000 | ||
| 363 | }; | ||
| 364 | |||
| 365 | /* | ||
| 366 | * Double-rate rule: we can support double rate iff channels == 2 | ||
| 367 | * (unimplemented) | ||
| 368 | */ | ||
| 369 | static int | ||
| 370 | aaci_rule_rate_by_channels(struct snd_pcm_hw_params *p, struct snd_pcm_hw_rule *rule) | ||
| 371 | { | ||
| 372 | struct aaci *aaci = rule->private; | ||
| 373 | unsigned int rate_mask = SNDRV_PCM_RATE_8000_48000|SNDRV_PCM_RATE_5512; | ||
| 374 | struct snd_interval *c = hw_param_interval(p, SNDRV_PCM_HW_PARAM_CHANNELS); | ||
| 375 | |||
| 376 | switch (c->max) { | ||
| 377 | case 6: | ||
| 378 | rate_mask &= aaci_rate_mask(aaci, ACSTREAM_LFE); | ||
| 379 | case 4: | ||
| 380 | rate_mask &= aaci_rate_mask(aaci, ACSTREAM_SURROUND); | ||
| 381 | case 2: | ||
| 382 | rate_mask &= aaci_rate_mask(aaci, ACSTREAM_FRONT); | ||
| 383 | } | ||
| 384 | |||
| 385 | return snd_interval_list(hw_param_interval(p, rule->var), | ||
| 386 | ARRAY_SIZE(rate_list), rate_list, | ||
| 387 | rate_mask); | ||
| 388 | } | ||
| 389 | |||
| 390 | static struct snd_pcm_hardware aaci_hw_info = { | 341 | static struct snd_pcm_hardware aaci_hw_info = { |
| 391 | .info = SNDRV_PCM_INFO_MMAP | | 342 | .info = SNDRV_PCM_INFO_MMAP | |
| 392 | SNDRV_PCM_INFO_MMAP_VALID | | 343 | SNDRV_PCM_INFO_MMAP_VALID | |
| @@ -400,10 +351,7 @@ static struct snd_pcm_hardware aaci_hw_info = { | |||
| 400 | */ | 351 | */ |
| 401 | .formats = SNDRV_PCM_FMTBIT_S16_LE, | 352 | .formats = SNDRV_PCM_FMTBIT_S16_LE, |
| 402 | 353 | ||
| 403 | /* should this be continuous or knot? */ | 354 | /* rates are setup from the AC'97 codec */ |
| 404 | .rates = SNDRV_PCM_RATE_CONTINUOUS, | ||
| 405 | .rate_max = 48000, | ||
| 406 | .rate_min = 4000, | ||
| 407 | .channels_min = 2, | 355 | .channels_min = 2, |
| 408 | .channels_max = 6, | 356 | .channels_max = 6, |
| 409 | .buffer_bytes_max = 64 * 1024, | 357 | .buffer_bytes_max = 64 * 1024, |
| @@ -423,6 +371,12 @@ static int __aaci_pcm_open(struct aaci *aaci, | |||
| 423 | aacirun->substream = substream; | 371 | aacirun->substream = substream; |
| 424 | runtime->private_data = aacirun; | 372 | runtime->private_data = aacirun; |
| 425 | runtime->hw = aaci_hw_info; | 373 | runtime->hw = aaci_hw_info; |
| 374 | runtime->hw.rates = aacirun->pcm->rates; | ||
| 375 | snd_pcm_limit_hw_rates(runtime); | ||
| 376 | |||
| 377 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK && | ||
| 378 | aacirun->pcm->r[1].slots) | ||
| 379 | snd_ac97_pcm_double_rate_rules(runtime); | ||
| 426 | 380 | ||
| 427 | /* | 381 | /* |
| 428 | * FIXME: ALSA specifies fifo_size in bytes. If we're in normal | 382 | * FIXME: ALSA specifies fifo_size in bytes. If we're in normal |
| @@ -433,17 +387,6 @@ static int __aaci_pcm_open(struct aaci *aaci, | |||
| 433 | */ | 387 | */ |
| 434 | runtime->hw.fifo_size = aaci->fifosize * 2; | 388 | runtime->hw.fifo_size = aaci->fifosize * 2; |
| 435 | 389 | ||
| 436 | /* | ||
| 437 | * Add rule describing hardware rate dependency | ||
| 438 | * on the number of channels. | ||
| 439 | */ | ||
| 440 | ret = snd_pcm_hw_rule_add(runtime, 0, SNDRV_PCM_HW_PARAM_RATE, | ||
| 441 | aaci_rule_rate_by_channels, aaci, | ||
| 442 | SNDRV_PCM_HW_PARAM_CHANNELS, | ||
| 443 | SNDRV_PCM_HW_PARAM_RATE, -1); | ||
| 444 | if (ret) | ||
| 445 | goto out; | ||
| 446 | |||
| 447 | ret = request_irq(aaci->dev->irq[0], aaci_irq, IRQF_SHARED|IRQF_DISABLED, | 390 | ret = request_irq(aaci->dev->irq[0], aaci_irq, IRQF_SHARED|IRQF_DISABLED, |
| 448 | DRIVER_NAME, aaci); | 391 | DRIVER_NAME, aaci); |
| 449 | if (ret) | 392 | if (ret) |
| @@ -507,18 +450,22 @@ static int aaci_pcm_hw_params(struct snd_pcm_substream *substream, | |||
| 507 | 450 | ||
| 508 | err = snd_pcm_lib_malloc_pages(substream, | 451 | err = snd_pcm_lib_malloc_pages(substream, |
| 509 | params_buffer_bytes(params)); | 452 | params_buffer_bytes(params)); |
| 510 | if (err < 0) | 453 | if (err >= 0) { |
| 511 | goto out; | 454 | unsigned int rate = params_rate(params); |
| 455 | int dbl = rate > 48000; | ||
| 512 | 456 | ||
| 513 | err = snd_ac97_pcm_open(aacirun->pcm, params_rate(params), | 457 | err = snd_ac97_pcm_open(aacirun->pcm, rate, |
| 514 | params_channels(params), | 458 | params_channels(params), |
| 515 | aacirun->pcm->r[0].slots); | 459 | aacirun->pcm->r[dbl].slots); |
| 516 | if (err) | ||
| 517 | goto out; | ||
| 518 | 460 | ||
| 519 | aacirun->pcm_open = 1; | 461 | aacirun->pcm_open = err == 0; |
| 462 | aacirun->cr = CR_FEN | CR_COMPACT | CR_SZ16; | ||
| 463 | aacirun->fifosz = aaci->fifosize * 4; | ||
| 464 | |||
| 465 | if (aacirun->cr & CR_COMPACT) | ||
| 466 | aacirun->fifosz >>= 1; | ||
| 467 | } | ||
| 520 | 468 | ||
| 521 | out: | ||
| 522 | return err; | 469 | return err; |
| 523 | } | 470 | } |
| 524 | 471 | ||
| @@ -527,7 +474,7 @@ static int aaci_pcm_prepare(struct snd_pcm_substream *substream) | |||
| 527 | struct snd_pcm_runtime *runtime = substream->runtime; | 474 | struct snd_pcm_runtime *runtime = substream->runtime; |
| 528 | struct aaci_runtime *aacirun = runtime->private_data; | 475 | struct aaci_runtime *aacirun = runtime->private_data; |
| 529 | 476 | ||
| 530 | aacirun->start = (void *)runtime->dma_area; | 477 | aacirun->start = runtime->dma_area; |
| 531 | aacirun->end = aacirun->start + snd_pcm_lib_buffer_bytes(substream); | 478 | aacirun->end = aacirun->start + snd_pcm_lib_buffer_bytes(substream); |
| 532 | aacirun->ptr = aacirun->start; | 479 | aacirun->ptr = aacirun->start; |
| 533 | aacirun->period = | 480 | aacirun->period = |
| @@ -627,14 +574,9 @@ static int aaci_pcm_playback_hw_params(struct snd_pcm_substream *substream, | |||
| 627 | * Enable FIFO, compact mode, 16 bits per sample. | 574 | * Enable FIFO, compact mode, 16 bits per sample. |
| 628 | * FIXME: double rate slots? | 575 | * FIXME: double rate slots? |
| 629 | */ | 576 | */ |
| 630 | if (ret >= 0) { | 577 | if (ret >= 0) |
| 631 | aacirun->cr = CR_FEN | CR_COMPACT | CR_SZ16; | ||
| 632 | aacirun->cr |= channels_to_txmask[channels]; | 578 | aacirun->cr |= channels_to_txmask[channels]; |
| 633 | 579 | ||
| 634 | aacirun->fifosz = aaci->fifosize * 4; | ||
| 635 | if (aacirun->cr & CR_COMPACT) | ||
| 636 | aacirun->fifosz >>= 1; | ||
| 637 | } | ||
| 638 | return ret; | 580 | return ret; |
| 639 | } | 581 | } |
| 640 | 582 | ||
| @@ -646,7 +588,7 @@ static void aaci_pcm_playback_stop(struct aaci_runtime *aacirun) | |||
| 646 | ie &= ~(IE_URIE|IE_TXIE); | 588 | ie &= ~(IE_URIE|IE_TXIE); |
| 647 | writel(ie, aacirun->base + AACI_IE); | 589 | writel(ie, aacirun->base + AACI_IE); |
| 648 | aacirun->cr &= ~CR_EN; | 590 | aacirun->cr &= ~CR_EN; |
| 649 | aaci_chan_wait_ready(aacirun); | 591 | aaci_chan_wait_ready(aacirun, SR_TXB); |
| 650 | writel(aacirun->cr, aacirun->base + AACI_TXCR); | 592 | writel(aacirun->cr, aacirun->base + AACI_TXCR); |
| 651 | } | 593 | } |
| 652 | 594 | ||
| @@ -654,7 +596,7 @@ static void aaci_pcm_playback_start(struct aaci_runtime *aacirun) | |||
| 654 | { | 596 | { |
| 655 | u32 ie; | 597 | u32 ie; |
| 656 | 598 | ||
| 657 | aaci_chan_wait_ready(aacirun); | 599 | aaci_chan_wait_ready(aacirun, SR_TXB); |
| 658 | aacirun->cr |= CR_EN; | 600 | aacirun->cr |= CR_EN; |
| 659 | 601 | ||
| 660 | ie = readl(aacirun->base + AACI_IE); | 602 | ie = readl(aacirun->base + AACI_IE); |
| @@ -665,12 +607,12 @@ static void aaci_pcm_playback_start(struct aaci_runtime *aacirun) | |||
| 665 | 607 | ||
| 666 | static int aaci_pcm_playback_trigger(struct snd_pcm_substream *substream, int cmd) | 608 | static int aaci_pcm_playback_trigger(struct snd_pcm_substream *substream, int cmd) |
| 667 | { | 609 | { |
| 668 | struct aaci *aaci = substream->private_data; | ||
| 669 | struct aaci_runtime *aacirun = substream->runtime->private_data; | 610 | struct aaci_runtime *aacirun = substream->runtime->private_data; |
| 670 | unsigned long flags; | 611 | unsigned long flags; |
| 671 | int ret = 0; | 612 | int ret = 0; |
| 672 | 613 | ||
| 673 | spin_lock_irqsave(&aaci->lock, flags); | 614 | spin_lock_irqsave(&aacirun->lock, flags); |
| 615 | |||
| 674 | switch (cmd) { | 616 | switch (cmd) { |
| 675 | case SNDRV_PCM_TRIGGER_START: | 617 | case SNDRV_PCM_TRIGGER_START: |
| 676 | aaci_pcm_playback_start(aacirun); | 618 | aaci_pcm_playback_start(aacirun); |
| @@ -697,7 +639,8 @@ static int aaci_pcm_playback_trigger(struct snd_pcm_substream *substream, int cm | |||
| 697 | default: | 639 | default: |
| 698 | ret = -EINVAL; | 640 | ret = -EINVAL; |
| 699 | } | 641 | } |
| 700 | spin_unlock_irqrestore(&aaci->lock, flags); | 642 | |
| 643 | spin_unlock_irqrestore(&aacirun->lock, flags); | ||
| 701 | 644 | ||
| 702 | return ret; | 645 | return ret; |
| 703 | } | 646 | } |
| @@ -721,18 +664,10 @@ static int aaci_pcm_capture_hw_params(struct snd_pcm_substream *substream, | |||
| 721 | int ret; | 664 | int ret; |
| 722 | 665 | ||
| 723 | ret = aaci_pcm_hw_params(substream, aacirun, params); | 666 | ret = aaci_pcm_hw_params(substream, aacirun, params); |
| 724 | 667 | if (ret >= 0) | |
| 725 | if (ret >= 0) { | ||
| 726 | aacirun->cr = CR_FEN | CR_COMPACT | CR_SZ16; | ||
| 727 | |||
| 728 | /* Line in record: slot 3 and 4 */ | 668 | /* Line in record: slot 3 and 4 */ |
| 729 | aacirun->cr |= CR_SL3 | CR_SL4; | 669 | aacirun->cr |= CR_SL3 | CR_SL4; |
| 730 | 670 | ||
| 731 | aacirun->fifosz = aaci->fifosize * 4; | ||
| 732 | |||
| 733 | if (aacirun->cr & CR_COMPACT) | ||
| 734 | aacirun->fifosz >>= 1; | ||
| 735 | } | ||
| 736 | return ret; | 671 | return ret; |
| 737 | } | 672 | } |
| 738 | 673 | ||
| @@ -740,7 +675,7 @@ static void aaci_pcm_capture_stop(struct aaci_runtime *aacirun) | |||
| 740 | { | 675 | { |
| 741 | u32 ie; | 676 | u32 ie; |
| 742 | 677 | ||
| 743 | aaci_chan_wait_ready(aacirun); | 678 | aaci_chan_wait_ready(aacirun, SR_RXB); |
| 744 | 679 | ||
| 745 | ie = readl(aacirun->base + AACI_IE); | 680 | ie = readl(aacirun->base + AACI_IE); |
| 746 | ie &= ~(IE_ORIE | IE_RXIE); | 681 | ie &= ~(IE_ORIE | IE_RXIE); |
| @@ -755,7 +690,7 @@ static void aaci_pcm_capture_start(struct aaci_runtime *aacirun) | |||
| 755 | { | 690 | { |
| 756 | u32 ie; | 691 | u32 ie; |
| 757 | 692 | ||
| 758 | aaci_chan_wait_ready(aacirun); | 693 | aaci_chan_wait_ready(aacirun, SR_RXB); |
| 759 | 694 | ||
| 760 | #ifdef DEBUG | 695 | #ifdef DEBUG |
| 761 | /* RX Timeout value: bits 28:17 in RXCR */ | 696 | /* RX Timeout value: bits 28:17 in RXCR */ |
| @@ -772,12 +707,11 @@ static void aaci_pcm_capture_start(struct aaci_runtime *aacirun) | |||
| 772 | 707 | ||
| 773 | static int aaci_pcm_capture_trigger(struct snd_pcm_substream *substream, int cmd) | 708 | static int aaci_pcm_capture_trigger(struct snd_pcm_substream *substream, int cmd) |
| 774 | { | 709 | { |
| 775 | struct aaci *aaci = substream->private_data; | ||
| 776 | struct aaci_runtime *aacirun = substream->runtime->private_data; | 710 | struct aaci_runtime *aacirun = substream->runtime->private_data; |
| 777 | unsigned long flags; | 711 | unsigned long flags; |
| 778 | int ret = 0; | 712 | int ret = 0; |
| 779 | 713 | ||
| 780 | spin_lock_irqsave(&aaci->lock, flags); | 714 | spin_lock_irqsave(&aacirun->lock, flags); |
| 781 | 715 | ||
| 782 | switch (cmd) { | 716 | switch (cmd) { |
| 783 | case SNDRV_PCM_TRIGGER_START: | 717 | case SNDRV_PCM_TRIGGER_START: |
| @@ -806,7 +740,7 @@ static int aaci_pcm_capture_trigger(struct snd_pcm_substream *substream, int cmd | |||
| 806 | ret = -EINVAL; | 740 | ret = -EINVAL; |
| 807 | } | 741 | } |
| 808 | 742 | ||
| 809 | spin_unlock_irqrestore(&aaci->lock, flags); | 743 | spin_unlock_irqrestore(&aacirun->lock, flags); |
| 810 | 744 | ||
| 811 | return ret; | 745 | return ret; |
| 812 | } | 746 | } |
| @@ -889,6 +823,12 @@ static struct ac97_pcm ac97_defs[] __devinitdata = { | |||
| 889 | (1 << AC97_SLOT_PCM_SRIGHT) | | 823 | (1 << AC97_SLOT_PCM_SRIGHT) | |
| 890 | (1 << AC97_SLOT_LFE), | 824 | (1 << AC97_SLOT_LFE), |
| 891 | }, | 825 | }, |
| 826 | [1] = { | ||
| 827 | .slots = (1 << AC97_SLOT_PCM_LEFT) | | ||
| 828 | (1 << AC97_SLOT_PCM_RIGHT) | | ||
| 829 | (1 << AC97_SLOT_PCM_LEFT_0) | | ||
| 830 | (1 << AC97_SLOT_PCM_RIGHT_0), | ||
| 831 | }, | ||
| 892 | }, | 832 | }, |
| 893 | }, | 833 | }, |
| 894 | [1] = { /* PCM in */ | 834 | [1] = { /* PCM in */ |
| @@ -1001,7 +941,6 @@ static struct aaci * __devinit aaci_init_card(struct amba_device *dev) | |||
| 1001 | 941 | ||
| 1002 | aaci = card->private_data; | 942 | aaci = card->private_data; |
| 1003 | mutex_init(&aaci->ac97_sem); | 943 | mutex_init(&aaci->ac97_sem); |
| 1004 | spin_lock_init(&aaci->lock); | ||
| 1005 | aaci->card = card; | 944 | aaci->card = card; |
| 1006 | aaci->dev = dev; | 945 | aaci->dev = dev; |
| 1007 | 946 | ||
| @@ -1028,7 +967,7 @@ static int __devinit aaci_init_pcm(struct aaci *aaci) | |||
| 1028 | snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &aaci_playback_ops); | 967 | snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &aaci_playback_ops); |
| 1029 | snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &aaci_capture_ops); | 968 | snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &aaci_capture_ops); |
| 1030 | snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV, | 969 | snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV, |
| 1031 | NULL, 0, 64 * 104); | 970 | NULL, 0, 64 * 1024); |
| 1032 | } | 971 | } |
| 1033 | 972 | ||
| 1034 | return ret; | 973 | return ret; |
| @@ -1088,12 +1027,14 @@ static int __devinit aaci_probe(struct amba_device *dev, struct amba_id *id) | |||
| 1088 | /* | 1027 | /* |
| 1089 | * Playback uses AACI channel 0 | 1028 | * Playback uses AACI channel 0 |
| 1090 | */ | 1029 | */ |
| 1030 | spin_lock_init(&aaci->playback.lock); | ||
| 1091 | aaci->playback.base = aaci->base + AACI_CSCH1; | 1031 | aaci->playback.base = aaci->base + AACI_CSCH1; |
| 1092 | aaci->playback.fifo = aaci->base + AACI_DR1; | 1032 | aaci->playback.fifo = aaci->base + AACI_DR1; |
| 1093 | 1033 | ||
| 1094 | /* | 1034 | /* |
| 1095 | * Capture uses AACI channel 0 | 1035 | * Capture uses AACI channel 0 |
| 1096 | */ | 1036 | */ |
| 1037 | spin_lock_init(&aaci->capture.lock); | ||
| 1097 | aaci->capture.base = aaci->base + AACI_CSCH1; | 1038 | aaci->capture.base = aaci->base + AACI_CSCH1; |
| 1098 | aaci->capture.fifo = aaci->base + AACI_DR1; | 1039 | aaci->capture.fifo = aaci->base + AACI_DR1; |
| 1099 | 1040 | ||
diff --git a/sound/arm/aaci.h b/sound/arm/aaci.h index 924f69c1c44c..6a4a2eebdda1 100644 --- a/sound/arm/aaci.h +++ b/sound/arm/aaci.h | |||
| @@ -202,6 +202,7 @@ | |||
| 202 | struct aaci_runtime { | 202 | struct aaci_runtime { |
| 203 | void __iomem *base; | 203 | void __iomem *base; |
| 204 | void __iomem *fifo; | 204 | void __iomem *fifo; |
| 205 | spinlock_t lock; | ||
| 205 | 206 | ||
| 206 | struct ac97_pcm *pcm; | 207 | struct ac97_pcm *pcm; |
| 207 | int pcm_open; | 208 | int pcm_open; |
| @@ -232,7 +233,6 @@ struct aaci { | |||
| 232 | struct snd_ac97 *ac97; | 233 | struct snd_ac97 *ac97; |
| 233 | 234 | ||
| 234 | u32 maincr; | 235 | u32 maincr; |
| 235 | spinlock_t lock; | ||
| 236 | 236 | ||
| 237 | struct aaci_runtime playback; | 237 | struct aaci_runtime playback; |
| 238 | struct aaci_runtime capture; | 238 | struct aaci_runtime capture; |
diff --git a/sound/core/pcm_lib.c b/sound/core/pcm_lib.c index 30f410832a25..a27545b23ee9 100644 --- a/sound/core/pcm_lib.c +++ b/sound/core/pcm_lib.c | |||
| @@ -758,7 +758,7 @@ int snd_interval_ratnum(struct snd_interval *i, | |||
| 758 | int diff; | 758 | int diff; |
| 759 | if (q == 0) | 759 | if (q == 0) |
| 760 | q = 1; | 760 | q = 1; |
| 761 | den = div_down(num, q); | 761 | den = div_up(num, q); |
| 762 | if (den < rats[k].den_min) | 762 | if (den < rats[k].den_min) |
| 763 | continue; | 763 | continue; |
| 764 | if (den > rats[k].den_max) | 764 | if (den > rats[k].den_max) |
| @@ -794,7 +794,7 @@ int snd_interval_ratnum(struct snd_interval *i, | |||
| 794 | i->empty = 1; | 794 | i->empty = 1; |
| 795 | return -EINVAL; | 795 | return -EINVAL; |
| 796 | } | 796 | } |
| 797 | den = div_up(num, q); | 797 | den = div_down(num, q); |
| 798 | if (den > rats[k].den_max) | 798 | if (den > rats[k].den_max) |
| 799 | continue; | 799 | continue; |
| 800 | if (den < rats[k].den_min) | 800 | if (den < rats[k].den_min) |
diff --git a/sound/isa/msnd/msnd_midi.c b/sound/isa/msnd/msnd_midi.c index cb9aa4c4edd0..4be562b2cf21 100644 --- a/sound/isa/msnd/msnd_midi.c +++ b/sound/isa/msnd/msnd_midi.c | |||
| @@ -162,7 +162,7 @@ int snd_msndmidi_new(struct snd_card *card, int device) | |||
| 162 | err = snd_rawmidi_new(card, "MSND-MIDI", device, 1, 1, &rmidi); | 162 | err = snd_rawmidi_new(card, "MSND-MIDI", device, 1, 1, &rmidi); |
| 163 | if (err < 0) | 163 | if (err < 0) |
| 164 | return err; | 164 | return err; |
| 165 | mpu = kcalloc(1, sizeof(*mpu), GFP_KERNEL); | 165 | mpu = kzalloc(sizeof(*mpu), GFP_KERNEL); |
| 166 | if (mpu == NULL) { | 166 | if (mpu == NULL) { |
| 167 | snd_device_free(card, rmidi); | 167 | snd_device_free(card, rmidi); |
| 168 | return -ENOMEM; | 168 | return -ENOMEM; |
diff --git a/sound/isa/sb/emu8000.c b/sound/isa/sb/emu8000.c index 96678d5d3834..751762f1c59a 100644 --- a/sound/isa/sb/emu8000.c +++ b/sound/isa/sb/emu8000.c | |||
| @@ -393,8 +393,6 @@ size_dram(struct snd_emu8000 *emu) | |||
| 393 | 393 | ||
| 394 | while (size < EMU8000_MAX_DRAM) { | 394 | while (size < EMU8000_MAX_DRAM) { |
| 395 | 395 | ||
| 396 | size += 512 * 1024; /* increment 512kbytes */ | ||
| 397 | |||
| 398 | /* Write a unique data on the test address. | 396 | /* Write a unique data on the test address. |
| 399 | * if the address is out of range, the data is written on | 397 | * if the address is out of range, the data is written on |
| 400 | * 0x200000(=EMU8000_DRAM_OFFSET). Then the id word is | 398 | * 0x200000(=EMU8000_DRAM_OFFSET). Then the id word is |
| @@ -414,7 +412,9 @@ size_dram(struct snd_emu8000 *emu) | |||
| 414 | /*snd_emu8000_read_wait(emu);*/ | 412 | /*snd_emu8000_read_wait(emu);*/ |
| 415 | EMU8000_SMLD_READ(emu); /* discard stale data */ | 413 | EMU8000_SMLD_READ(emu); /* discard stale data */ |
| 416 | if (EMU8000_SMLD_READ(emu) != UNIQUE_ID2) | 414 | if (EMU8000_SMLD_READ(emu) != UNIQUE_ID2) |
| 417 | break; /* we must have wrapped around */ | 415 | break; /* no memory at this address */ |
| 416 | |||
| 417 | size += 512 * 1024; /* increment 512kbytes */ | ||
| 418 | 418 | ||
| 419 | snd_emu8000_read_wait(emu); | 419 | snd_emu8000_read_wait(emu); |
| 420 | 420 | ||
diff --git a/sound/mips/sgio2audio.c b/sound/mips/sgio2audio.c index 8691f4cf6191..f1d9d16b5486 100644 --- a/sound/mips/sgio2audio.c +++ b/sound/mips/sgio2audio.c | |||
| @@ -609,7 +609,7 @@ static int snd_sgio2audio_pcm_hw_params(struct snd_pcm_substream *substream, | |||
| 609 | /* alloc virtual 'dma' area */ | 609 | /* alloc virtual 'dma' area */ |
| 610 | if (runtime->dma_area) | 610 | if (runtime->dma_area) |
| 611 | vfree(runtime->dma_area); | 611 | vfree(runtime->dma_area); |
| 612 | runtime->dma_area = vmalloc(size); | 612 | runtime->dma_area = vmalloc_user(size); |
| 613 | if (runtime->dma_area == NULL) | 613 | if (runtime->dma_area == NULL) |
| 614 | return -ENOMEM; | 614 | return -ENOMEM; |
| 615 | runtime->dma_bytes = size; | 615 | runtime->dma_bytes = size; |
diff --git a/sound/oss/pss.c b/sound/oss/pss.c index 83f5ee236b12..e19dd5dcc2de 100644 --- a/sound/oss/pss.c +++ b/sound/oss/pss.c | |||
| @@ -269,7 +269,7 @@ static int pss_reset_dsp(pss_confdata * devc) | |||
| 269 | unsigned long i, limit = jiffies + HZ/10; | 269 | unsigned long i, limit = jiffies + HZ/10; |
| 270 | 270 | ||
| 271 | outw(0x2000, REG(PSS_CONTROL)); | 271 | outw(0x2000, REG(PSS_CONTROL)); |
| 272 | for (i = 0; i < 32768 && (limit-jiffies >= 0); i++) | 272 | for (i = 0; i < 32768 && time_after_eq(limit, jiffies); i++) |
| 273 | inw(REG(PSS_CONTROL)); | 273 | inw(REG(PSS_CONTROL)); |
| 274 | outw(0x0000, REG(PSS_CONTROL)); | 274 | outw(0x0000, REG(PSS_CONTROL)); |
| 275 | return 1; | 275 | return 1; |
| @@ -369,11 +369,11 @@ static int pss_download_boot(pss_confdata * devc, unsigned char *block, int size | |||
| 369 | outw(0, REG(PSS_DATA)); | 369 | outw(0, REG(PSS_DATA)); |
| 370 | 370 | ||
| 371 | limit = jiffies + HZ/10; | 371 | limit = jiffies + HZ/10; |
| 372 | for (i = 0; i < 32768 && (limit - jiffies >= 0); i++) | 372 | for (i = 0; i < 32768 && time_after_eq(limit, jiffies); i++) |
| 373 | val = inw(REG(PSS_STATUS)); | 373 | val = inw(REG(PSS_STATUS)); |
| 374 | 374 | ||
| 375 | limit = jiffies + HZ/10; | 375 | limit = jiffies + HZ/10; |
| 376 | for (i = 0; i < 32768 && (limit-jiffies >= 0); i++) | 376 | for (i = 0; i < 32768 && time_after_eq(limit, jiffies); i++) |
| 377 | { | 377 | { |
| 378 | val = inw(REG(PSS_STATUS)); | 378 | val = inw(REG(PSS_STATUS)); |
| 379 | if (val & 0x4000) | 379 | if (val & 0x4000) |
diff --git a/sound/pci/hda/patch_conexant.c b/sound/pci/hda/patch_conexant.c index a09c03c3f62b..c578c28f368e 100644 --- a/sound/pci/hda/patch_conexant.c +++ b/sound/pci/hda/patch_conexant.c | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | 29 | ||
| 30 | #include "hda_codec.h" | 30 | #include "hda_codec.h" |
| 31 | #include "hda_local.h" | 31 | #include "hda_local.h" |
| 32 | #include "hda_beep.h" | ||
| 32 | 33 | ||
| 33 | #define CXT_PIN_DIR_IN 0x00 | 34 | #define CXT_PIN_DIR_IN 0x00 |
| 34 | #define CXT_PIN_DIR_OUT 0x01 | 35 | #define CXT_PIN_DIR_OUT 0x01 |
| @@ -111,6 +112,7 @@ struct conexant_spec { | |||
| 111 | unsigned int dell_automute; | 112 | unsigned int dell_automute; |
| 112 | unsigned int port_d_mode; | 113 | unsigned int port_d_mode; |
| 113 | unsigned char ext_mic_bias; | 114 | unsigned char ext_mic_bias; |
| 115 | unsigned int dell_vostro; | ||
| 114 | }; | 116 | }; |
| 115 | 117 | ||
| 116 | static int conexant_playback_pcm_open(struct hda_pcm_stream *hinfo, | 118 | static int conexant_playback_pcm_open(struct hda_pcm_stream *hinfo, |
| @@ -476,6 +478,7 @@ static void conexant_free(struct hda_codec *codec) | |||
| 476 | snd_array_free(&spec->jacks); | 478 | snd_array_free(&spec->jacks); |
| 477 | } | 479 | } |
| 478 | #endif | 480 | #endif |
| 481 | snd_hda_detach_beep_device(codec); | ||
| 479 | kfree(codec->spec); | 482 | kfree(codec->spec); |
| 480 | } | 483 | } |
| 481 | 484 | ||
| @@ -2109,9 +2112,12 @@ static int cxt5066_mic_boost_mux_enum_get(struct snd_kcontrol *kcontrol, | |||
| 2109 | { | 2112 | { |
| 2110 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); | 2113 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); |
| 2111 | int val; | 2114 | int val; |
| 2115 | hda_nid_t nid = kcontrol->private_value & 0xff; | ||
| 2116 | int inout = (kcontrol->private_value & 0x100) ? | ||
| 2117 | AC_AMP_GET_INPUT : AC_AMP_GET_OUTPUT; | ||
| 2112 | 2118 | ||
| 2113 | val = snd_hda_codec_read(codec, 0x17, 0, | 2119 | val = snd_hda_codec_read(codec, nid, 0, |
| 2114 | AC_VERB_GET_AMP_GAIN_MUTE, AC_AMP_GET_OUTPUT); | 2120 | AC_VERB_GET_AMP_GAIN_MUTE, inout); |
| 2115 | 2121 | ||
| 2116 | ucontrol->value.enumerated.item[0] = val & AC_AMP_GAIN; | 2122 | ucontrol->value.enumerated.item[0] = val & AC_AMP_GAIN; |
| 2117 | return 0; | 2123 | return 0; |
| @@ -2123,6 +2129,9 @@ static int cxt5066_mic_boost_mux_enum_put(struct snd_kcontrol *kcontrol, | |||
| 2123 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); | 2129 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); |
| 2124 | const struct hda_input_mux *imux = &cxt5066_analog_mic_boost; | 2130 | const struct hda_input_mux *imux = &cxt5066_analog_mic_boost; |
| 2125 | unsigned int idx; | 2131 | unsigned int idx; |
| 2132 | hda_nid_t nid = kcontrol->private_value & 0xff; | ||
| 2133 | int inout = (kcontrol->private_value & 0x100) ? | ||
| 2134 | AC_AMP_SET_INPUT : AC_AMP_SET_OUTPUT; | ||
| 2126 | 2135 | ||
| 2127 | if (!imux->num_items) | 2136 | if (!imux->num_items) |
| 2128 | return 0; | 2137 | return 0; |
| @@ -2130,9 +2139,9 @@ static int cxt5066_mic_boost_mux_enum_put(struct snd_kcontrol *kcontrol, | |||
| 2130 | if (idx >= imux->num_items) | 2139 | if (idx >= imux->num_items) |
| 2131 | idx = imux->num_items - 1; | 2140 | idx = imux->num_items - 1; |
| 2132 | 2141 | ||
| 2133 | snd_hda_codec_write_cache(codec, 0x17, 0, | 2142 | snd_hda_codec_write_cache(codec, nid, 0, |
| 2134 | AC_VERB_SET_AMP_GAIN_MUTE, | 2143 | AC_VERB_SET_AMP_GAIN_MUTE, |
| 2135 | AC_AMP_SET_RIGHT | AC_AMP_SET_LEFT | AC_AMP_SET_OUTPUT | | 2144 | AC_AMP_SET_RIGHT | AC_AMP_SET_LEFT | inout | |
| 2136 | imux->items[idx].index); | 2145 | imux->items[idx].index); |
| 2137 | 2146 | ||
| 2138 | return 1; | 2147 | return 1; |
| @@ -2201,10 +2210,11 @@ static struct snd_kcontrol_new cxt5066_mixers[] = { | |||
| 2201 | 2210 | ||
| 2202 | { | 2211 | { |
| 2203 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2212 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
| 2204 | .name = "Analog Mic Boost Capture Enum", | 2213 | .name = "Ext Mic Boost Capture Enum", |
| 2205 | .info = cxt5066_mic_boost_mux_enum_info, | 2214 | .info = cxt5066_mic_boost_mux_enum_info, |
| 2206 | .get = cxt5066_mic_boost_mux_enum_get, | 2215 | .get = cxt5066_mic_boost_mux_enum_get, |
| 2207 | .put = cxt5066_mic_boost_mux_enum_put, | 2216 | .put = cxt5066_mic_boost_mux_enum_put, |
| 2217 | .private_value = 0x17, | ||
| 2208 | }, | 2218 | }, |
| 2209 | 2219 | ||
| 2210 | HDA_BIND_VOL("Capture Volume", &cxt5066_bind_capture_vol_others), | 2220 | HDA_BIND_VOL("Capture Volume", &cxt5066_bind_capture_vol_others), |
| @@ -2212,6 +2222,19 @@ static struct snd_kcontrol_new cxt5066_mixers[] = { | |||
| 2212 | {} | 2222 | {} |
| 2213 | }; | 2223 | }; |
| 2214 | 2224 | ||
| 2225 | static struct snd_kcontrol_new cxt5066_vostro_mixers[] = { | ||
| 2226 | { | ||
| 2227 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | ||
| 2228 | .name = "Int Mic Boost Capture Enum", | ||
| 2229 | .info = cxt5066_mic_boost_mux_enum_info, | ||
| 2230 | .get = cxt5066_mic_boost_mux_enum_get, | ||
| 2231 | .put = cxt5066_mic_boost_mux_enum_put, | ||
| 2232 | .private_value = 0x23 | 0x100, | ||
| 2233 | }, | ||
| 2234 | HDA_CODEC_VOLUME_MONO("Beep Playback Volume", 0x13, 1, 0x0, HDA_OUTPUT), | ||
| 2235 | {} | ||
| 2236 | }; | ||
| 2237 | |||
| 2215 | static struct hda_verb cxt5066_init_verbs[] = { | 2238 | static struct hda_verb cxt5066_init_verbs[] = { |
| 2216 | {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, /* Port B */ | 2239 | {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, /* Port B */ |
| 2217 | {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, /* Port C */ | 2240 | {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, /* Port C */ |
| @@ -2397,11 +2420,16 @@ static struct hda_verb cxt5066_init_verbs_portd_lo[] = { | |||
| 2397 | /* initialize jack-sensing, too */ | 2420 | /* initialize jack-sensing, too */ |
| 2398 | static int cxt5066_init(struct hda_codec *codec) | 2421 | static int cxt5066_init(struct hda_codec *codec) |
| 2399 | { | 2422 | { |
| 2423 | struct conexant_spec *spec = codec->spec; | ||
| 2424 | |||
| 2400 | snd_printdd("CXT5066: init\n"); | 2425 | snd_printdd("CXT5066: init\n"); |
| 2401 | conexant_init(codec); | 2426 | conexant_init(codec); |
| 2402 | if (codec->patch_ops.unsol_event) { | 2427 | if (codec->patch_ops.unsol_event) { |
| 2403 | cxt5066_hp_automute(codec); | 2428 | cxt5066_hp_automute(codec); |
| 2404 | cxt5066_automic(codec); | 2429 | if (spec->dell_vostro) |
| 2430 | cxt5066_vostro_automic(codec); | ||
| 2431 | else | ||
| 2432 | cxt5066_automic(codec); | ||
| 2405 | } | 2433 | } |
| 2406 | return 0; | 2434 | return 0; |
| 2407 | } | 2435 | } |
| @@ -2500,7 +2528,10 @@ static int patch_cxt5066(struct hda_codec *codec) | |||
| 2500 | spec->init_verbs[0] = cxt5066_init_verbs_vostro; | 2528 | spec->init_verbs[0] = cxt5066_init_verbs_vostro; |
| 2501 | spec->mixers[spec->num_mixers++] = cxt5066_mixer_master_olpc; | 2529 | spec->mixers[spec->num_mixers++] = cxt5066_mixer_master_olpc; |
| 2502 | spec->mixers[spec->num_mixers++] = cxt5066_mixers; | 2530 | spec->mixers[spec->num_mixers++] = cxt5066_mixers; |
| 2531 | spec->mixers[spec->num_mixers++] = cxt5066_vostro_mixers; | ||
| 2503 | spec->port_d_mode = 0; | 2532 | spec->port_d_mode = 0; |
| 2533 | spec->dell_vostro = 1; | ||
| 2534 | snd_hda_attach_beep_device(codec, 0x13); | ||
| 2504 | 2535 | ||
| 2505 | /* no S/PDIF out */ | 2536 | /* no S/PDIF out */ |
| 2506 | spec->multiout.dig_out_nid = 0; | 2537 | spec->multiout.dig_out_nid = 0; |
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index aeed4cc5aa79..c7465053d6bb 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
| @@ -131,8 +131,8 @@ enum { | |||
| 131 | enum { | 131 | enum { |
| 132 | ALC269_BASIC, | 132 | ALC269_BASIC, |
| 133 | ALC269_QUANTA_FL1, | 133 | ALC269_QUANTA_FL1, |
| 134 | ALC269_ASUS_EEEPC_P703, | 134 | ALC269_ASUS_AMIC, |
| 135 | ALC269_ASUS_EEEPC_P901, | 135 | ALC269_ASUS_DMIC, |
| 136 | ALC269_FUJITSU, | 136 | ALC269_FUJITSU, |
| 137 | ALC269_LIFEBOOK, | 137 | ALC269_LIFEBOOK, |
| 138 | ALC269_AUTO, | 138 | ALC269_AUTO, |
| @@ -188,6 +188,8 @@ enum { | |||
| 188 | ALC663_ASUS_MODE4, | 188 | ALC663_ASUS_MODE4, |
| 189 | ALC663_ASUS_MODE5, | 189 | ALC663_ASUS_MODE5, |
| 190 | ALC663_ASUS_MODE6, | 190 | ALC663_ASUS_MODE6, |
| 191 | ALC663_ASUS_MODE7, | ||
| 192 | ALC663_ASUS_MODE8, | ||
| 191 | ALC272_DELL, | 193 | ALC272_DELL, |
| 192 | ALC272_DELL_ZM1, | 194 | ALC272_DELL_ZM1, |
| 193 | ALC272_SAMSUNG_NC10, | 195 | ALC272_SAMSUNG_NC10, |
| @@ -335,6 +337,9 @@ struct alc_spec { | |||
| 335 | /* hooks */ | 337 | /* hooks */ |
| 336 | void (*init_hook)(struct hda_codec *codec); | 338 | void (*init_hook)(struct hda_codec *codec); |
| 337 | void (*unsol_event)(struct hda_codec *codec, unsigned int res); | 339 | void (*unsol_event)(struct hda_codec *codec, unsigned int res); |
| 340 | #ifdef CONFIG_SND_HDA_POWER_SAVE | ||
| 341 | void (*power_hook)(struct hda_codec *codec, int power); | ||
| 342 | #endif | ||
| 338 | 343 | ||
| 339 | /* for pin sensing */ | 344 | /* for pin sensing */ |
| 340 | unsigned int sense_updated: 1; | 345 | unsigned int sense_updated: 1; |
| @@ -386,6 +391,7 @@ struct alc_config_preset { | |||
| 386 | void (*init_hook)(struct hda_codec *); | 391 | void (*init_hook)(struct hda_codec *); |
| 387 | #ifdef CONFIG_SND_HDA_POWER_SAVE | 392 | #ifdef CONFIG_SND_HDA_POWER_SAVE |
| 388 | struct hda_amp_list *loopbacks; | 393 | struct hda_amp_list *loopbacks; |
| 394 | void (*power_hook)(struct hda_codec *codec, int power); | ||
| 389 | #endif | 395 | #endif |
| 390 | }; | 396 | }; |
| 391 | 397 | ||
| @@ -898,6 +904,7 @@ static void setup_preset(struct hda_codec *codec, | |||
| 898 | spec->unsol_event = preset->unsol_event; | 904 | spec->unsol_event = preset->unsol_event; |
| 899 | spec->init_hook = preset->init_hook; | 905 | spec->init_hook = preset->init_hook; |
| 900 | #ifdef CONFIG_SND_HDA_POWER_SAVE | 906 | #ifdef CONFIG_SND_HDA_POWER_SAVE |
| 907 | spec->power_hook = preset->power_hook; | ||
| 901 | spec->loopback.amplist = preset->loopbacks; | 908 | spec->loopback.amplist = preset->loopbacks; |
| 902 | #endif | 909 | #endif |
| 903 | 910 | ||
| @@ -1663,9 +1670,6 @@ static struct hda_verb alc889_acer_aspire_8930g_verbs[] = { | |||
| 1663 | /* some bit here disables the other DACs. Init=0x4900 */ | 1670 | /* some bit here disables the other DACs. Init=0x4900 */ |
| 1664 | {0x20, AC_VERB_SET_COEF_INDEX, 0x08}, | 1671 | {0x20, AC_VERB_SET_COEF_INDEX, 0x08}, |
| 1665 | {0x20, AC_VERB_SET_PROC_COEF, 0x0000}, | 1672 | {0x20, AC_VERB_SET_PROC_COEF, 0x0000}, |
| 1666 | /* Enable amplifiers */ | ||
| 1667 | {0x14, AC_VERB_SET_EAPD_BTLENABLE, 0x02}, | ||
| 1668 | {0x15, AC_VERB_SET_EAPD_BTLENABLE, 0x02}, | ||
| 1669 | /* DMIC fix | 1673 | /* DMIC fix |
| 1670 | * This laptop has a stereo digital microphone. The mics are only 1cm apart | 1674 | * This laptop has a stereo digital microphone. The mics are only 1cm apart |
| 1671 | * which makes the stereo useless. However, either the mic or the ALC889 | 1675 | * which makes the stereo useless. However, either the mic or the ALC889 |
| @@ -1778,6 +1782,25 @@ static struct snd_kcontrol_new alc888_base_mixer[] = { | |||
| 1778 | { } /* end */ | 1782 | { } /* end */ |
| 1779 | }; | 1783 | }; |
| 1780 | 1784 | ||
| 1785 | static struct snd_kcontrol_new alc889_acer_aspire_8930g_mixer[] = { | ||
| 1786 | HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT), | ||
| 1787 | HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT), | ||
| 1788 | HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT), | ||
| 1789 | HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT), | ||
| 1790 | HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, | ||
| 1791 | HDA_OUTPUT), | ||
| 1792 | HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT), | ||
| 1793 | HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT), | ||
| 1794 | HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT), | ||
| 1795 | HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT), | ||
| 1796 | HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT), | ||
| 1797 | HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT), | ||
| 1798 | HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT), | ||
| 1799 | HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT), | ||
| 1800 | { } /* end */ | ||
| 1801 | }; | ||
| 1802 | |||
| 1803 | |||
| 1781 | static void alc888_acer_aspire_4930g_setup(struct hda_codec *codec) | 1804 | static void alc888_acer_aspire_4930g_setup(struct hda_codec *codec) |
| 1782 | { | 1805 | { |
| 1783 | struct alc_spec *spec = codec->spec; | 1806 | struct alc_spec *spec = codec->spec; |
| @@ -1808,6 +1831,16 @@ static void alc889_acer_aspire_8930g_setup(struct hda_codec *codec) | |||
| 1808 | spec->autocfg.speaker_pins[2] = 0x1b; | 1831 | spec->autocfg.speaker_pins[2] = 0x1b; |
| 1809 | } | 1832 | } |
| 1810 | 1833 | ||
| 1834 | #ifdef CONFIG_SND_HDA_POWER_SAVE | ||
| 1835 | static void alc889_power_eapd(struct hda_codec *codec, int power) | ||
| 1836 | { | ||
| 1837 | snd_hda_codec_write(codec, 0x14, 0, | ||
| 1838 | AC_VERB_SET_EAPD_BTLENABLE, power ? 2 : 0); | ||
| 1839 | snd_hda_codec_write(codec, 0x15, 0, | ||
| 1840 | AC_VERB_SET_EAPD_BTLENABLE, power ? 2 : 0); | ||
| 1841 | } | ||
| 1842 | #endif | ||
| 1843 | |||
| 1811 | /* | 1844 | /* |
| 1812 | * ALC880 3-stack model | 1845 | * ALC880 3-stack model |
| 1813 | * | 1846 | * |
| @@ -3601,12 +3634,29 @@ static void alc_free(struct hda_codec *codec) | |||
| 3601 | snd_hda_detach_beep_device(codec); | 3634 | snd_hda_detach_beep_device(codec); |
| 3602 | } | 3635 | } |
| 3603 | 3636 | ||
| 3637 | #ifdef CONFIG_SND_HDA_POWER_SAVE | ||
| 3638 | static int alc_suspend(struct hda_codec *codec, pm_message_t state) | ||
| 3639 | { | ||
| 3640 | struct alc_spec *spec = codec->spec; | ||
| 3641 | if (spec && spec->power_hook) | ||
| 3642 | spec->power_hook(codec, 0); | ||
| 3643 | return 0; | ||
| 3644 | } | ||
| 3645 | #endif | ||
| 3646 | |||
| 3604 | #ifdef SND_HDA_NEEDS_RESUME | 3647 | #ifdef SND_HDA_NEEDS_RESUME |
| 3605 | static int alc_resume(struct hda_codec *codec) | 3648 | static int alc_resume(struct hda_codec *codec) |
| 3606 | { | 3649 | { |
| 3650 | #ifdef CONFIG_SND_HDA_POWER_SAVE | ||
| 3651 | struct alc_spec *spec = codec->spec; | ||
| 3652 | #endif | ||
| 3607 | codec->patch_ops.init(codec); | 3653 | codec->patch_ops.init(codec); |
| 3608 | snd_hda_codec_resume_amp(codec); | 3654 | snd_hda_codec_resume_amp(codec); |
| 3609 | snd_hda_codec_resume_cache(codec); | 3655 | snd_hda_codec_resume_cache(codec); |
| 3656 | #ifdef CONFIG_SND_HDA_POWER_SAVE | ||
| 3657 | if (spec && spec->power_hook) | ||
| 3658 | spec->power_hook(codec, 1); | ||
| 3659 | #endif | ||
| 3610 | return 0; | 3660 | return 0; |
| 3611 | } | 3661 | } |
| 3612 | #endif | 3662 | #endif |
| @@ -3623,6 +3673,7 @@ static struct hda_codec_ops alc_patch_ops = { | |||
| 3623 | .resume = alc_resume, | 3673 | .resume = alc_resume, |
| 3624 | #endif | 3674 | #endif |
| 3625 | #ifdef CONFIG_SND_HDA_POWER_SAVE | 3675 | #ifdef CONFIG_SND_HDA_POWER_SAVE |
| 3676 | .suspend = alc_suspend, | ||
| 3626 | .check_power_status = alc_check_power_status, | 3677 | .check_power_status = alc_check_power_status, |
| 3627 | #endif | 3678 | #endif |
| 3628 | }; | 3679 | }; |
| @@ -8919,7 +8970,7 @@ static struct snd_pci_quirk alc882_cfg_tbl[] = { | |||
| 8919 | SND_PCI_QUIRK(0x1462, 0x040d, "MSI", ALC883_TARGA_2ch_DIG), | 8970 | SND_PCI_QUIRK(0x1462, 0x040d, "MSI", ALC883_TARGA_2ch_DIG), |
| 8920 | SND_PCI_QUIRK(0x1462, 0x0579, "MSI", ALC883_TARGA_2ch_DIG), | 8971 | SND_PCI_QUIRK(0x1462, 0x0579, "MSI", ALC883_TARGA_2ch_DIG), |
| 8921 | SND_PCI_QUIRK(0x1462, 0x28fb, "Targa T8", ALC882_TARGA), /* MSI-1049 T8 */ | 8972 | SND_PCI_QUIRK(0x1462, 0x28fb, "Targa T8", ALC882_TARGA), /* MSI-1049 T8 */ |
| 8922 | SND_PCI_QUIRK(0x1462, 0x2fb3, "MSI", ALC883_TARGA_2ch_DIG), | 8973 | SND_PCI_QUIRK(0x1462, 0x2fb3, "MSI", ALC882_AUTO), |
| 8923 | SND_PCI_QUIRK(0x1462, 0x6668, "MSI", ALC882_6ST_DIG), | 8974 | SND_PCI_QUIRK(0x1462, 0x6668, "MSI", ALC882_6ST_DIG), |
| 8924 | SND_PCI_QUIRK(0x1462, 0x3729, "MSI S420", ALC883_TARGA_DIG), | 8975 | SND_PCI_QUIRK(0x1462, 0x3729, "MSI S420", ALC883_TARGA_DIG), |
| 8925 | SND_PCI_QUIRK(0x1462, 0x3783, "NEC S970", ALC883_TARGA_DIG), | 8976 | SND_PCI_QUIRK(0x1462, 0x3783, "NEC S970", ALC883_TARGA_DIG), |
| @@ -9282,6 +9333,7 @@ static struct alc_config_preset alc882_presets[] = { | |||
| 9282 | .dac_nids = alc883_dac_nids, | 9333 | .dac_nids = alc883_dac_nids, |
| 9283 | .adc_nids = alc883_adc_nids_alt, | 9334 | .adc_nids = alc883_adc_nids_alt, |
| 9284 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt), | 9335 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt), |
| 9336 | .capsrc_nids = alc883_capsrc_nids, | ||
| 9285 | .dig_out_nid = ALC883_DIGOUT_NID, | 9337 | .dig_out_nid = ALC883_DIGOUT_NID, |
| 9286 | .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes), | 9338 | .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes), |
| 9287 | .channel_mode = alc883_3ST_2ch_modes, | 9339 | .channel_mode = alc883_3ST_2ch_modes, |
| @@ -9378,10 +9430,11 @@ static struct alc_config_preset alc882_presets[] = { | |||
| 9378 | .init_hook = alc_automute_amp, | 9430 | .init_hook = alc_automute_amp, |
| 9379 | }, | 9431 | }, |
| 9380 | [ALC888_ACER_ASPIRE_8930G] = { | 9432 | [ALC888_ACER_ASPIRE_8930G] = { |
| 9381 | .mixers = { alc888_base_mixer, | 9433 | .mixers = { alc889_acer_aspire_8930g_mixer, |
| 9382 | alc883_chmode_mixer }, | 9434 | alc883_chmode_mixer }, |
| 9383 | .init_verbs = { alc883_init_verbs, alc880_gpio1_init_verbs, | 9435 | .init_verbs = { alc883_init_verbs, alc880_gpio1_init_verbs, |
| 9384 | alc889_acer_aspire_8930g_verbs }, | 9436 | alc889_acer_aspire_8930g_verbs, |
| 9437 | alc889_eapd_verbs}, | ||
| 9385 | .num_dacs = ARRAY_SIZE(alc883_dac_nids), | 9438 | .num_dacs = ARRAY_SIZE(alc883_dac_nids), |
| 9386 | .dac_nids = alc883_dac_nids, | 9439 | .dac_nids = alc883_dac_nids, |
| 9387 | .num_adc_nids = ARRAY_SIZE(alc889_adc_nids), | 9440 | .num_adc_nids = ARRAY_SIZE(alc889_adc_nids), |
| @@ -9398,6 +9451,9 @@ static struct alc_config_preset alc882_presets[] = { | |||
| 9398 | .unsol_event = alc_automute_amp_unsol_event, | 9451 | .unsol_event = alc_automute_amp_unsol_event, |
| 9399 | .setup = alc889_acer_aspire_8930g_setup, | 9452 | .setup = alc889_acer_aspire_8930g_setup, |
| 9400 | .init_hook = alc_automute_amp, | 9453 | .init_hook = alc_automute_amp, |
| 9454 | #ifdef CONFIG_SND_HDA_POWER_SAVE | ||
| 9455 | .power_hook = alc889_power_eapd, | ||
| 9456 | #endif | ||
| 9401 | }, | 9457 | }, |
| 9402 | [ALC888_ACER_ASPIRE_7730G] = { | 9458 | [ALC888_ACER_ASPIRE_7730G] = { |
| 9403 | .mixers = { alc883_3ST_6ch_mixer, | 9459 | .mixers = { alc883_3ST_6ch_mixer, |
| @@ -9428,6 +9484,7 @@ static struct alc_config_preset alc882_presets[] = { | |||
| 9428 | .dac_nids = alc883_dac_nids, | 9484 | .dac_nids = alc883_dac_nids, |
| 9429 | .adc_nids = alc883_adc_nids_alt, | 9485 | .adc_nids = alc883_adc_nids_alt, |
| 9430 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt), | 9486 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt), |
| 9487 | .capsrc_nids = alc883_capsrc_nids, | ||
| 9431 | .num_channel_mode = ARRAY_SIZE(alc883_sixstack_modes), | 9488 | .num_channel_mode = ARRAY_SIZE(alc883_sixstack_modes), |
| 9432 | .channel_mode = alc883_sixstack_modes, | 9489 | .channel_mode = alc883_sixstack_modes, |
| 9433 | .input_mux = &alc883_capture_source, | 9490 | .input_mux = &alc883_capture_source, |
| @@ -9489,6 +9546,7 @@ static struct alc_config_preset alc882_presets[] = { | |||
| 9489 | .dac_nids = alc883_dac_nids, | 9546 | .dac_nids = alc883_dac_nids, |
| 9490 | .adc_nids = alc883_adc_nids_alt, | 9547 | .adc_nids = alc883_adc_nids_alt, |
| 9491 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt), | 9548 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt), |
| 9549 | .capsrc_nids = alc883_capsrc_nids, | ||
| 9492 | .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes), | 9550 | .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes), |
| 9493 | .channel_mode = alc883_3ST_2ch_modes, | 9551 | .channel_mode = alc883_3ST_2ch_modes, |
| 9494 | .input_mux = &alc883_lenovo_101e_capture_source, | 9552 | .input_mux = &alc883_lenovo_101e_capture_source, |
| @@ -9668,6 +9726,7 @@ static struct alc_config_preset alc882_presets[] = { | |||
| 9668 | alc880_gpio1_init_verbs }, | 9726 | alc880_gpio1_init_verbs }, |
| 9669 | .adc_nids = alc883_adc_nids, | 9727 | .adc_nids = alc883_adc_nids, |
| 9670 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids), | 9728 | .num_adc_nids = ARRAY_SIZE(alc883_adc_nids), |
| 9729 | .capsrc_nids = alc883_capsrc_nids, | ||
| 9671 | .dac_nids = alc883_dac_nids, | 9730 | .dac_nids = alc883_dac_nids, |
| 9672 | .num_dacs = ARRAY_SIZE(alc883_dac_nids), | 9731 | .num_dacs = ARRAY_SIZE(alc883_dac_nids), |
| 9673 | .channel_mode = alc889A_mb31_6ch_modes, | 9732 | .channel_mode = alc889A_mb31_6ch_modes, |
| @@ -10678,6 +10737,13 @@ static struct hda_verb alc262_lenovo_3000_unsol_verbs[] = { | |||
| 10678 | {} | 10737 | {} |
| 10679 | }; | 10738 | }; |
| 10680 | 10739 | ||
| 10740 | static struct hda_verb alc262_lenovo_3000_init_verbs[] = { | ||
| 10741 | /* Front Mic pin: input vref at 50% */ | ||
| 10742 | {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50}, | ||
| 10743 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, | ||
| 10744 | {} | ||
| 10745 | }; | ||
| 10746 | |||
| 10681 | static struct hda_input_mux alc262_fujitsu_capture_source = { | 10747 | static struct hda_input_mux alc262_fujitsu_capture_source = { |
| 10682 | .num_items = 3, | 10748 | .num_items = 3, |
| 10683 | .items = { | 10749 | .items = { |
| @@ -11720,7 +11786,8 @@ static struct alc_config_preset alc262_presets[] = { | |||
| 11720 | [ALC262_LENOVO_3000] = { | 11786 | [ALC262_LENOVO_3000] = { |
| 11721 | .mixers = { alc262_lenovo_3000_mixer }, | 11787 | .mixers = { alc262_lenovo_3000_mixer }, |
| 11722 | .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs, | 11788 | .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs, |
| 11723 | alc262_lenovo_3000_unsol_verbs }, | 11789 | alc262_lenovo_3000_unsol_verbs, |
| 11790 | alc262_lenovo_3000_init_verbs }, | ||
| 11724 | .num_dacs = ARRAY_SIZE(alc262_dac_nids), | 11791 | .num_dacs = ARRAY_SIZE(alc262_dac_nids), |
| 11725 | .dac_nids = alc262_dac_nids, | 11792 | .dac_nids = alc262_dac_nids, |
| 11726 | .hp_nid = 0x03, | 11793 | .hp_nid = 0x03, |
| @@ -12857,7 +12924,7 @@ static int patch_alc268(struct hda_codec *codec) | |||
| 12857 | int board_config; | 12924 | int board_config; |
| 12858 | int i, has_beep, err; | 12925 | int i, has_beep, err; |
| 12859 | 12926 | ||
| 12860 | spec = kcalloc(1, sizeof(*spec), GFP_KERNEL); | 12927 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); |
| 12861 | if (spec == NULL) | 12928 | if (spec == NULL) |
| 12862 | return -ENOMEM; | 12929 | return -ENOMEM; |
| 12863 | 12930 | ||
| @@ -13232,10 +13299,12 @@ static struct hda_verb alc269_eeepc_amic_init_verbs[] = { | |||
| 13232 | /* toggle speaker-output according to the hp-jack state */ | 13299 | /* toggle speaker-output according to the hp-jack state */ |
| 13233 | static void alc269_speaker_automute(struct hda_codec *codec) | 13300 | static void alc269_speaker_automute(struct hda_codec *codec) |
| 13234 | { | 13301 | { |
| 13302 | struct alc_spec *spec = codec->spec; | ||
| 13303 | unsigned int nid = spec->autocfg.hp_pins[0]; | ||
| 13235 | unsigned int present; | 13304 | unsigned int present; |
| 13236 | unsigned char bits; | 13305 | unsigned char bits; |
| 13237 | 13306 | ||
| 13238 | present = snd_hda_jack_detect(codec, 0x15); | 13307 | present = snd_hda_jack_detect(codec, nid); |
| 13239 | bits = present ? AMP_IN_MUTE(0) : 0; | 13308 | bits = present ? AMP_IN_MUTE(0) : 0; |
| 13240 | snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0, | 13309 | snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0, |
| 13241 | AMP_IN_MUTE(0), bits); | 13310 | AMP_IN_MUTE(0), bits); |
| @@ -13460,8 +13529,8 @@ static void alc269_auto_init(struct hda_codec *codec) | |||
| 13460 | static const char *alc269_models[ALC269_MODEL_LAST] = { | 13529 | static const char *alc269_models[ALC269_MODEL_LAST] = { |
| 13461 | [ALC269_BASIC] = "basic", | 13530 | [ALC269_BASIC] = "basic", |
| 13462 | [ALC269_QUANTA_FL1] = "quanta", | 13531 | [ALC269_QUANTA_FL1] = "quanta", |
| 13463 | [ALC269_ASUS_EEEPC_P703] = "eeepc-p703", | 13532 | [ALC269_ASUS_AMIC] = "asus-amic", |
| 13464 | [ALC269_ASUS_EEEPC_P901] = "eeepc-p901", | 13533 | [ALC269_ASUS_DMIC] = "asus-dmic", |
| 13465 | [ALC269_FUJITSU] = "fujitsu", | 13534 | [ALC269_FUJITSU] = "fujitsu", |
| 13466 | [ALC269_LIFEBOOK] = "lifebook", | 13535 | [ALC269_LIFEBOOK] = "lifebook", |
| 13467 | [ALC269_AUTO] = "auto", | 13536 | [ALC269_AUTO] = "auto", |
| @@ -13470,18 +13539,41 @@ static const char *alc269_models[ALC269_MODEL_LAST] = { | |||
| 13470 | static struct snd_pci_quirk alc269_cfg_tbl[] = { | 13539 | static struct snd_pci_quirk alc269_cfg_tbl[] = { |
| 13471 | SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_QUANTA_FL1), | 13540 | SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_QUANTA_FL1), |
| 13472 | SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A", | 13541 | SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A", |
| 13473 | ALC269_ASUS_EEEPC_P703), | 13542 | ALC269_ASUS_AMIC), |
| 13474 | SND_PCI_QUIRK(0x1043, 0x1883, "ASUS F81Se", ALC269_ASUS_EEEPC_P703), | 13543 | SND_PCI_QUIRK(0x1043, 0x1133, "ASUS UJ20ft", ALC269_ASUS_AMIC), |
| 13475 | SND_PCI_QUIRK(0x1043, 0x16a3, "ASUS F5Q", ALC269_ASUS_EEEPC_P703), | 13544 | SND_PCI_QUIRK(0x1043, 0x1273, "ASUS UL80JT", ALC269_ASUS_AMIC), |
| 13476 | SND_PCI_QUIRK(0x1043, 0x1723, "ASUS P80", ALC269_ASUS_EEEPC_P703), | 13545 | SND_PCI_QUIRK(0x1043, 0x1283, "ASUS U53Jc", ALC269_ASUS_AMIC), |
| 13477 | SND_PCI_QUIRK(0x1043, 0x1773, "ASUS U20A", ALC269_ASUS_EEEPC_P703), | 13546 | SND_PCI_QUIRK(0x1043, 0x12b3, "ASUS N82Jv", ALC269_ASUS_AMIC), |
| 13478 | SND_PCI_QUIRK(0x1043, 0x1743, "ASUS U80", ALC269_ASUS_EEEPC_P703), | 13547 | SND_PCI_QUIRK(0x1043, 0x13a3, "ASUS UL30Vt", ALC269_ASUS_AMIC), |
| 13479 | SND_PCI_QUIRK(0x1043, 0x1653, "ASUS U50", ALC269_ASUS_EEEPC_P703), | 13548 | SND_PCI_QUIRK(0x1043, 0x1373, "ASUS G73JX", ALC269_ASUS_AMIC), |
| 13549 | SND_PCI_QUIRK(0x1043, 0x1383, "ASUS UJ30Jc", ALC269_ASUS_AMIC), | ||
| 13550 | SND_PCI_QUIRK(0x1043, 0x13d3, "ASUS N61JA", ALC269_ASUS_AMIC), | ||
| 13551 | SND_PCI_QUIRK(0x1043, 0x1413, "ASUS UL50", ALC269_ASUS_AMIC), | ||
| 13552 | SND_PCI_QUIRK(0x1043, 0x1443, "ASUS UL30", ALC269_ASUS_AMIC), | ||
| 13553 | SND_PCI_QUIRK(0x1043, 0x1453, "ASUS M60Jv", ALC269_ASUS_AMIC), | ||
| 13554 | SND_PCI_QUIRK(0x1043, 0x1483, "ASUS UL80", ALC269_ASUS_AMIC), | ||
| 13555 | SND_PCI_QUIRK(0x1043, 0x14f3, "ASUS F83Vf", ALC269_ASUS_AMIC), | ||
| 13556 | SND_PCI_QUIRK(0x1043, 0x14e3, "ASUS UL20", ALC269_ASUS_AMIC), | ||
| 13557 | SND_PCI_QUIRK(0x1043, 0x1513, "ASUS UX30", ALC269_ASUS_AMIC), | ||
| 13558 | SND_PCI_QUIRK(0x1043, 0x15a3, "ASUS N60Jv", ALC269_ASUS_AMIC), | ||
| 13559 | SND_PCI_QUIRK(0x1043, 0x15b3, "ASUS N60Dp", ALC269_ASUS_AMIC), | ||
| 13560 | SND_PCI_QUIRK(0x1043, 0x15c3, "ASUS N70De", ALC269_ASUS_AMIC), | ||
| 13561 | SND_PCI_QUIRK(0x1043, 0x15e3, "ASUS F83T", ALC269_ASUS_AMIC), | ||
| 13562 | SND_PCI_QUIRK(0x1043, 0x1643, "ASUS M60J", ALC269_ASUS_AMIC), | ||
| 13563 | SND_PCI_QUIRK(0x1043, 0x1653, "ASUS U50", ALC269_ASUS_AMIC), | ||
| 13564 | SND_PCI_QUIRK(0x1043, 0x1693, "ASUS F50N", ALC269_ASUS_AMIC), | ||
| 13565 | SND_PCI_QUIRK(0x1043, 0x16a3, "ASUS F5Q", ALC269_ASUS_AMIC), | ||
| 13566 | SND_PCI_QUIRK(0x1043, 0x16e3, "ASUS UX50", ALC269_ASUS_DMIC), | ||
| 13567 | SND_PCI_QUIRK(0x1043, 0x1723, "ASUS P80", ALC269_ASUS_AMIC), | ||
| 13568 | SND_PCI_QUIRK(0x1043, 0x1743, "ASUS U80", ALC269_ASUS_AMIC), | ||
| 13569 | SND_PCI_QUIRK(0x1043, 0x1773, "ASUS U20A", ALC269_ASUS_AMIC), | ||
| 13570 | SND_PCI_QUIRK(0x1043, 0x1883, "ASUS F81Se", ALC269_ASUS_AMIC), | ||
| 13480 | SND_PCI_QUIRK(0x1043, 0x831a, "ASUS Eeepc P901", | 13571 | SND_PCI_QUIRK(0x1043, 0x831a, "ASUS Eeepc P901", |
| 13481 | ALC269_ASUS_EEEPC_P901), | 13572 | ALC269_ASUS_DMIC), |
| 13482 | SND_PCI_QUIRK(0x1043, 0x834a, "ASUS Eeepc S101", | 13573 | SND_PCI_QUIRK(0x1043, 0x834a, "ASUS Eeepc S101", |
| 13483 | ALC269_ASUS_EEEPC_P901), | 13574 | ALC269_ASUS_DMIC), |
| 13484 | SND_PCI_QUIRK(0x1043, 0x16e3, "ASUS UX50", ALC269_ASUS_EEEPC_P901), | 13575 | SND_PCI_QUIRK(0x1043, 0x8398, "ASUS P1005HA", ALC269_ASUS_DMIC), |
| 13576 | SND_PCI_QUIRK(0x1043, 0x83ce, "ASUS P1005HA", ALC269_ASUS_DMIC), | ||
| 13485 | SND_PCI_QUIRK(0x1734, 0x115d, "FSC Amilo", ALC269_FUJITSU), | 13577 | SND_PCI_QUIRK(0x1734, 0x115d, "FSC Amilo", ALC269_FUJITSU), |
| 13486 | SND_PCI_QUIRK(0x10cf, 0x1475, "Lifebook ICH9M-based", ALC269_LIFEBOOK), | 13578 | SND_PCI_QUIRK(0x10cf, 0x1475, "Lifebook ICH9M-based", ALC269_LIFEBOOK), |
| 13487 | {} | 13579 | {} |
| @@ -13511,7 +13603,7 @@ static struct alc_config_preset alc269_presets[] = { | |||
| 13511 | .setup = alc269_quanta_fl1_setup, | 13603 | .setup = alc269_quanta_fl1_setup, |
| 13512 | .init_hook = alc269_quanta_fl1_init_hook, | 13604 | .init_hook = alc269_quanta_fl1_init_hook, |
| 13513 | }, | 13605 | }, |
| 13514 | [ALC269_ASUS_EEEPC_P703] = { | 13606 | [ALC269_ASUS_AMIC] = { |
| 13515 | .mixers = { alc269_eeepc_mixer }, | 13607 | .mixers = { alc269_eeepc_mixer }, |
| 13516 | .cap_mixer = alc269_epc_capture_mixer, | 13608 | .cap_mixer = alc269_epc_capture_mixer, |
| 13517 | .init_verbs = { alc269_init_verbs, | 13609 | .init_verbs = { alc269_init_verbs, |
| @@ -13525,7 +13617,7 @@ static struct alc_config_preset alc269_presets[] = { | |||
| 13525 | .setup = alc269_eeepc_amic_setup, | 13617 | .setup = alc269_eeepc_amic_setup, |
| 13526 | .init_hook = alc269_eeepc_inithook, | 13618 | .init_hook = alc269_eeepc_inithook, |
| 13527 | }, | 13619 | }, |
| 13528 | [ALC269_ASUS_EEEPC_P901] = { | 13620 | [ALC269_ASUS_DMIC] = { |
| 13529 | .mixers = { alc269_eeepc_mixer }, | 13621 | .mixers = { alc269_eeepc_mixer }, |
| 13530 | .cap_mixer = alc269_epc_capture_mixer, | 13622 | .cap_mixer = alc269_epc_capture_mixer, |
| 13531 | .init_verbs = { alc269_init_verbs, | 13623 | .init_verbs = { alc269_init_verbs, |
| @@ -16160,6 +16252,52 @@ static struct snd_kcontrol_new alc663_g50v_mixer[] = { | |||
| 16160 | { } /* end */ | 16252 | { } /* end */ |
| 16161 | }; | 16253 | }; |
| 16162 | 16254 | ||
| 16255 | static struct hda_bind_ctls alc663_asus_mode7_8_all_bind_switch = { | ||
| 16256 | .ops = &snd_hda_bind_sw, | ||
| 16257 | .values = { | ||
| 16258 | HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT), | ||
| 16259 | HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT), | ||
| 16260 | HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT), | ||
| 16261 | HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT), | ||
| 16262 | HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT), | ||
| 16263 | 0 | ||
| 16264 | }, | ||
| 16265 | }; | ||
| 16266 | |||
| 16267 | static struct hda_bind_ctls alc663_asus_mode7_8_sp_bind_switch = { | ||
| 16268 | .ops = &snd_hda_bind_sw, | ||
| 16269 | .values = { | ||
| 16270 | HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT), | ||
| 16271 | HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT), | ||
| 16272 | 0 | ||
| 16273 | }, | ||
| 16274 | }; | ||
| 16275 | |||
| 16276 | static struct snd_kcontrol_new alc663_mode7_mixer[] = { | ||
| 16277 | HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch), | ||
| 16278 | HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol), | ||
| 16279 | HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch), | ||
| 16280 | HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x1b, 0x0, HDA_OUTPUT), | ||
| 16281 | HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT), | ||
| 16282 | HDA_CODEC_VOLUME("IntMic Playback Volume", 0x0b, 0x0, HDA_INPUT), | ||
| 16283 | HDA_CODEC_MUTE("IntMic Playback Switch", 0x0b, 0x0, HDA_INPUT), | ||
| 16284 | HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT), | ||
| 16285 | HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT), | ||
| 16286 | { } /* end */ | ||
| 16287 | }; | ||
| 16288 | |||
| 16289 | static struct snd_kcontrol_new alc663_mode8_mixer[] = { | ||
| 16290 | HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch), | ||
| 16291 | HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol), | ||
| 16292 | HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch), | ||
| 16293 | HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x15, 0x0, HDA_OUTPUT), | ||
| 16294 | HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT), | ||
| 16295 | HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT), | ||
| 16296 | HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT), | ||
| 16297 | { } /* end */ | ||
| 16298 | }; | ||
| 16299 | |||
| 16300 | |||
| 16163 | static struct snd_kcontrol_new alc662_chmode_mixer[] = { | 16301 | static struct snd_kcontrol_new alc662_chmode_mixer[] = { |
| 16164 | { | 16302 | { |
| 16165 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 16303 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
| @@ -16447,6 +16585,45 @@ static struct hda_verb alc272_dell_init_verbs[] = { | |||
| 16447 | {} | 16585 | {} |
| 16448 | }; | 16586 | }; |
| 16449 | 16587 | ||
| 16588 | static struct hda_verb alc663_mode7_init_verbs[] = { | ||
| 16589 | {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, | ||
| 16590 | {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, | ||
| 16591 | {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, | ||
| 16592 | {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | ||
| 16593 | {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, | ||
| 16594 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | ||
| 16595 | {0x1b, AC_VERB_SET_CONNECT_SEL, 0x01}, | ||
| 16596 | {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, | ||
| 16597 | {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | ||
| 16598 | {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */ | ||
| 16599 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, | ||
| 16600 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)}, | ||
| 16601 | {0x19, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT}, | ||
| 16602 | {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT}, | ||
| 16603 | {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT}, | ||
| 16604 | {} | ||
| 16605 | }; | ||
| 16606 | |||
| 16607 | static struct hda_verb alc663_mode8_init_verbs[] = { | ||
| 16608 | {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, | ||
| 16609 | {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, | ||
| 16610 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | ||
| 16611 | {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, | ||
| 16612 | {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, | ||
| 16613 | {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, | ||
| 16614 | {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | ||
| 16615 | {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, | ||
| 16616 | {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, | ||
| 16617 | {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | ||
| 16618 | {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */ | ||
| 16619 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, | ||
| 16620 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)}, | ||
| 16621 | {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT}, | ||
| 16622 | {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT}, | ||
| 16623 | {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT}, | ||
| 16624 | {} | ||
| 16625 | }; | ||
| 16626 | |||
| 16450 | static struct snd_kcontrol_new alc662_auto_capture_mixer[] = { | 16627 | static struct snd_kcontrol_new alc662_auto_capture_mixer[] = { |
| 16451 | HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT), | 16628 | HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT), |
| 16452 | HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT), | 16629 | HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT), |
| @@ -16626,6 +16803,54 @@ static void alc663_two_hp_m2_speaker_automute(struct hda_codec *codec) | |||
| 16626 | } | 16803 | } |
| 16627 | } | 16804 | } |
| 16628 | 16805 | ||
| 16806 | static void alc663_two_hp_m7_speaker_automute(struct hda_codec *codec) | ||
| 16807 | { | ||
| 16808 | unsigned int present1, present2; | ||
| 16809 | |||
| 16810 | present1 = snd_hda_codec_read(codec, 0x1b, 0, | ||
| 16811 | AC_VERB_GET_PIN_SENSE, 0) | ||
| 16812 | & AC_PINSENSE_PRESENCE; | ||
| 16813 | present2 = snd_hda_codec_read(codec, 0x21, 0, | ||
| 16814 | AC_VERB_GET_PIN_SENSE, 0) | ||
| 16815 | & AC_PINSENSE_PRESENCE; | ||
| 16816 | |||
| 16817 | if (present1 || present2) { | ||
| 16818 | snd_hda_codec_write_cache(codec, 0x14, 0, | ||
| 16819 | AC_VERB_SET_PIN_WIDGET_CONTROL, 0); | ||
| 16820 | snd_hda_codec_write_cache(codec, 0x17, 0, | ||
| 16821 | AC_VERB_SET_PIN_WIDGET_CONTROL, 0); | ||
| 16822 | } else { | ||
| 16823 | snd_hda_codec_write_cache(codec, 0x14, 0, | ||
| 16824 | AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT); | ||
| 16825 | snd_hda_codec_write_cache(codec, 0x17, 0, | ||
| 16826 | AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT); | ||
| 16827 | } | ||
| 16828 | } | ||
| 16829 | |||
| 16830 | static void alc663_two_hp_m8_speaker_automute(struct hda_codec *codec) | ||
| 16831 | { | ||
| 16832 | unsigned int present1, present2; | ||
| 16833 | |||
| 16834 | present1 = snd_hda_codec_read(codec, 0x21, 0, | ||
| 16835 | AC_VERB_GET_PIN_SENSE, 0) | ||
| 16836 | & AC_PINSENSE_PRESENCE; | ||
| 16837 | present2 = snd_hda_codec_read(codec, 0x15, 0, | ||
| 16838 | AC_VERB_GET_PIN_SENSE, 0) | ||
| 16839 | & AC_PINSENSE_PRESENCE; | ||
| 16840 | |||
| 16841 | if (present1 || present2) { | ||
| 16842 | snd_hda_codec_write_cache(codec, 0x14, 0, | ||
| 16843 | AC_VERB_SET_PIN_WIDGET_CONTROL, 0); | ||
| 16844 | snd_hda_codec_write_cache(codec, 0x17, 0, | ||
| 16845 | AC_VERB_SET_PIN_WIDGET_CONTROL, 0); | ||
| 16846 | } else { | ||
| 16847 | snd_hda_codec_write_cache(codec, 0x14, 0, | ||
| 16848 | AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT); | ||
| 16849 | snd_hda_codec_write_cache(codec, 0x17, 0, | ||
| 16850 | AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT); | ||
| 16851 | } | ||
| 16852 | } | ||
| 16853 | |||
| 16629 | static void alc663_m51va_unsol_event(struct hda_codec *codec, | 16854 | static void alc663_m51va_unsol_event(struct hda_codec *codec, |
| 16630 | unsigned int res) | 16855 | unsigned int res) |
| 16631 | { | 16856 | { |
| @@ -16645,7 +16870,7 @@ static void alc663_m51va_setup(struct hda_codec *codec) | |||
| 16645 | spec->ext_mic.pin = 0x18; | 16870 | spec->ext_mic.pin = 0x18; |
| 16646 | spec->ext_mic.mux_idx = 0; | 16871 | spec->ext_mic.mux_idx = 0; |
| 16647 | spec->int_mic.pin = 0x12; | 16872 | spec->int_mic.pin = 0x12; |
| 16648 | spec->int_mic.mux_idx = 1; | 16873 | spec->int_mic.mux_idx = 9; |
| 16649 | spec->auto_mic = 1; | 16874 | spec->auto_mic = 1; |
| 16650 | } | 16875 | } |
| 16651 | 16876 | ||
| @@ -16657,7 +16882,17 @@ static void alc663_m51va_inithook(struct hda_codec *codec) | |||
| 16657 | 16882 | ||
| 16658 | /* ***************** Mode1 ******************************/ | 16883 | /* ***************** Mode1 ******************************/ |
| 16659 | #define alc663_mode1_unsol_event alc663_m51va_unsol_event | 16884 | #define alc663_mode1_unsol_event alc663_m51va_unsol_event |
| 16660 | #define alc663_mode1_setup alc663_m51va_setup | 16885 | |
| 16886 | static void alc663_mode1_setup(struct hda_codec *codec) | ||
| 16887 | { | ||
| 16888 | struct alc_spec *spec = codec->spec; | ||
| 16889 | spec->ext_mic.pin = 0x18; | ||
| 16890 | spec->ext_mic.mux_idx = 0; | ||
| 16891 | spec->int_mic.pin = 0x19; | ||
| 16892 | spec->int_mic.mux_idx = 1; | ||
| 16893 | spec->auto_mic = 1; | ||
| 16894 | } | ||
| 16895 | |||
| 16661 | #define alc663_mode1_inithook alc663_m51va_inithook | 16896 | #define alc663_mode1_inithook alc663_m51va_inithook |
| 16662 | 16897 | ||
| 16663 | /* ***************** Mode2 ******************************/ | 16898 | /* ***************** Mode2 ******************************/ |
| @@ -16674,7 +16909,7 @@ static void alc662_mode2_unsol_event(struct hda_codec *codec, | |||
| 16674 | } | 16909 | } |
| 16675 | } | 16910 | } |
| 16676 | 16911 | ||
| 16677 | #define alc662_mode2_setup alc663_m51va_setup | 16912 | #define alc662_mode2_setup alc663_mode1_setup |
| 16678 | 16913 | ||
| 16679 | static void alc662_mode2_inithook(struct hda_codec *codec) | 16914 | static void alc662_mode2_inithook(struct hda_codec *codec) |
| 16680 | { | 16915 | { |
| @@ -16695,7 +16930,7 @@ static void alc663_mode3_unsol_event(struct hda_codec *codec, | |||
| 16695 | } | 16930 | } |
| 16696 | } | 16931 | } |
| 16697 | 16932 | ||
| 16698 | #define alc663_mode3_setup alc663_m51va_setup | 16933 | #define alc663_mode3_setup alc663_mode1_setup |
| 16699 | 16934 | ||
| 16700 | static void alc663_mode3_inithook(struct hda_codec *codec) | 16935 | static void alc663_mode3_inithook(struct hda_codec *codec) |
| 16701 | { | 16936 | { |
| @@ -16716,7 +16951,7 @@ static void alc663_mode4_unsol_event(struct hda_codec *codec, | |||
| 16716 | } | 16951 | } |
| 16717 | } | 16952 | } |
| 16718 | 16953 | ||
| 16719 | #define alc663_mode4_setup alc663_m51va_setup | 16954 | #define alc663_mode4_setup alc663_mode1_setup |
| 16720 | 16955 | ||
| 16721 | static void alc663_mode4_inithook(struct hda_codec *codec) | 16956 | static void alc663_mode4_inithook(struct hda_codec *codec) |
| 16722 | { | 16957 | { |
| @@ -16737,7 +16972,7 @@ static void alc663_mode5_unsol_event(struct hda_codec *codec, | |||
| 16737 | } | 16972 | } |
| 16738 | } | 16973 | } |
| 16739 | 16974 | ||
| 16740 | #define alc663_mode5_setup alc663_m51va_setup | 16975 | #define alc663_mode5_setup alc663_mode1_setup |
| 16741 | 16976 | ||
| 16742 | static void alc663_mode5_inithook(struct hda_codec *codec) | 16977 | static void alc663_mode5_inithook(struct hda_codec *codec) |
| 16743 | { | 16978 | { |
| @@ -16758,7 +16993,7 @@ static void alc663_mode6_unsol_event(struct hda_codec *codec, | |||
| 16758 | } | 16993 | } |
| 16759 | } | 16994 | } |
| 16760 | 16995 | ||
| 16761 | #define alc663_mode6_setup alc663_m51va_setup | 16996 | #define alc663_mode6_setup alc663_mode1_setup |
| 16762 | 16997 | ||
| 16763 | static void alc663_mode6_inithook(struct hda_codec *codec) | 16998 | static void alc663_mode6_inithook(struct hda_codec *codec) |
| 16764 | { | 16999 | { |
| @@ -16766,6 +17001,50 @@ static void alc663_mode6_inithook(struct hda_codec *codec) | |||
| 16766 | alc_mic_automute(codec); | 17001 | alc_mic_automute(codec); |
| 16767 | } | 17002 | } |
| 16768 | 17003 | ||
| 17004 | /* ***************** Mode7 ******************************/ | ||
| 17005 | static void alc663_mode7_unsol_event(struct hda_codec *codec, | ||
| 17006 | unsigned int res) | ||
| 17007 | { | ||
| 17008 | switch (res >> 26) { | ||
| 17009 | case ALC880_HP_EVENT: | ||
| 17010 | alc663_two_hp_m7_speaker_automute(codec); | ||
| 17011 | break; | ||
| 17012 | case ALC880_MIC_EVENT: | ||
| 17013 | alc_mic_automute(codec); | ||
| 17014 | break; | ||
| 17015 | } | ||
| 17016 | } | ||
| 17017 | |||
| 17018 | #define alc663_mode7_setup alc663_mode1_setup | ||
| 17019 | |||
| 17020 | static void alc663_mode7_inithook(struct hda_codec *codec) | ||
| 17021 | { | ||
| 17022 | alc663_two_hp_m7_speaker_automute(codec); | ||
| 17023 | alc_mic_automute(codec); | ||
| 17024 | } | ||
| 17025 | |||
| 17026 | /* ***************** Mode8 ******************************/ | ||
| 17027 | static void alc663_mode8_unsol_event(struct hda_codec *codec, | ||
| 17028 | unsigned int res) | ||
| 17029 | { | ||
| 17030 | switch (res >> 26) { | ||
| 17031 | case ALC880_HP_EVENT: | ||
| 17032 | alc663_two_hp_m8_speaker_automute(codec); | ||
| 17033 | break; | ||
| 17034 | case ALC880_MIC_EVENT: | ||
| 17035 | alc_mic_automute(codec); | ||
| 17036 | break; | ||
| 17037 | } | ||
| 17038 | } | ||
| 17039 | |||
| 17040 | #define alc663_mode8_setup alc663_m51va_setup | ||
| 17041 | |||
| 17042 | static void alc663_mode8_inithook(struct hda_codec *codec) | ||
| 17043 | { | ||
| 17044 | alc663_two_hp_m8_speaker_automute(codec); | ||
| 17045 | alc_mic_automute(codec); | ||
| 17046 | } | ||
| 17047 | |||
| 16769 | static void alc663_g71v_hp_automute(struct hda_codec *codec) | 17048 | static void alc663_g71v_hp_automute(struct hda_codec *codec) |
| 16770 | { | 17049 | { |
| 16771 | unsigned int present; | 17050 | unsigned int present; |
| @@ -16900,6 +17179,8 @@ static const char *alc662_models[ALC662_MODEL_LAST] = { | |||
| 16900 | [ALC663_ASUS_MODE4] = "asus-mode4", | 17179 | [ALC663_ASUS_MODE4] = "asus-mode4", |
| 16901 | [ALC663_ASUS_MODE5] = "asus-mode5", | 17180 | [ALC663_ASUS_MODE5] = "asus-mode5", |
| 16902 | [ALC663_ASUS_MODE6] = "asus-mode6", | 17181 | [ALC663_ASUS_MODE6] = "asus-mode6", |
| 17182 | [ALC663_ASUS_MODE7] = "asus-mode7", | ||
| 17183 | [ALC663_ASUS_MODE8] = "asus-mode8", | ||
| 16903 | [ALC272_DELL] = "dell", | 17184 | [ALC272_DELL] = "dell", |
| 16904 | [ALC272_DELL_ZM1] = "dell-zm1", | 17185 | [ALC272_DELL_ZM1] = "dell-zm1", |
| 16905 | [ALC272_SAMSUNG_NC10] = "samsung-nc10", | 17186 | [ALC272_SAMSUNG_NC10] = "samsung-nc10", |
| @@ -16916,12 +17197,22 @@ static struct snd_pci_quirk alc662_cfg_tbl[] = { | |||
| 16916 | SND_PCI_QUIRK(0x1043, 0x11d3, "ASUS NB", ALC663_ASUS_MODE1), | 17197 | SND_PCI_QUIRK(0x1043, 0x11d3, "ASUS NB", ALC663_ASUS_MODE1), |
| 16917 | SND_PCI_QUIRK(0x1043, 0x11f3, "ASUS NB", ALC662_ASUS_MODE2), | 17198 | SND_PCI_QUIRK(0x1043, 0x11f3, "ASUS NB", ALC662_ASUS_MODE2), |
| 16918 | SND_PCI_QUIRK(0x1043, 0x1203, "ASUS NB", ALC663_ASUS_MODE1), | 17199 | SND_PCI_QUIRK(0x1043, 0x1203, "ASUS NB", ALC663_ASUS_MODE1), |
| 17200 | SND_PCI_QUIRK(0x1043, 0x1303, "ASUS G60J", ALC663_ASUS_MODE1), | ||
| 17201 | SND_PCI_QUIRK(0x1043, 0x1333, "ASUS G60Jx", ALC663_ASUS_MODE1), | ||
| 16919 | SND_PCI_QUIRK(0x1043, 0x1339, "ASUS NB", ALC662_ASUS_MODE2), | 17202 | SND_PCI_QUIRK(0x1043, 0x1339, "ASUS NB", ALC662_ASUS_MODE2), |
| 17203 | SND_PCI_QUIRK(0x1043, 0x13e3, "ASUS N71JA", ALC663_ASUS_MODE7), | ||
| 17204 | SND_PCI_QUIRK(0x1043, 0x1463, "ASUS N71", ALC663_ASUS_MODE7), | ||
| 17205 | SND_PCI_QUIRK(0x1043, 0x14d3, "ASUS G72", ALC663_ASUS_MODE8), | ||
| 17206 | SND_PCI_QUIRK(0x1043, 0x1563, "ASUS N90", ALC663_ASUS_MODE3), | ||
| 17207 | SND_PCI_QUIRK(0x1043, 0x15d3, "ASUS N50SF F50SF", ALC663_ASUS_MODE1), | ||
| 16920 | SND_PCI_QUIRK(0x1043, 0x16c3, "ASUS NB", ALC662_ASUS_MODE2), | 17208 | SND_PCI_QUIRK(0x1043, 0x16c3, "ASUS NB", ALC662_ASUS_MODE2), |
| 17209 | SND_PCI_QUIRK(0x1043, 0x16f3, "ASUS K40C K50C", ALC662_ASUS_MODE2), | ||
| 17210 | SND_PCI_QUIRK(0x1043, 0x1733, "ASUS N81De", ALC663_ASUS_MODE1), | ||
| 16921 | SND_PCI_QUIRK(0x1043, 0x1753, "ASUS NB", ALC662_ASUS_MODE2), | 17211 | SND_PCI_QUIRK(0x1043, 0x1753, "ASUS NB", ALC662_ASUS_MODE2), |
| 16922 | SND_PCI_QUIRK(0x1043, 0x1763, "ASUS NB", ALC663_ASUS_MODE6), | 17212 | SND_PCI_QUIRK(0x1043, 0x1763, "ASUS NB", ALC663_ASUS_MODE6), |
| 16923 | SND_PCI_QUIRK(0x1043, 0x1765, "ASUS NB", ALC663_ASUS_MODE6), | 17213 | SND_PCI_QUIRK(0x1043, 0x1765, "ASUS NB", ALC663_ASUS_MODE6), |
| 16924 | SND_PCI_QUIRK(0x1043, 0x1783, "ASUS NB", ALC662_ASUS_MODE2), | 17214 | SND_PCI_QUIRK(0x1043, 0x1783, "ASUS NB", ALC662_ASUS_MODE2), |
| 17215 | SND_PCI_QUIRK(0x1043, 0x1793, "ASUS F50GX", ALC663_ASUS_MODE1), | ||
| 16925 | SND_PCI_QUIRK(0x1043, 0x17b3, "ASUS F70SL", ALC663_ASUS_MODE3), | 17216 | SND_PCI_QUIRK(0x1043, 0x17b3, "ASUS F70SL", ALC663_ASUS_MODE3), |
| 16926 | SND_PCI_QUIRK(0x1043, 0x17c3, "ASUS UX20", ALC663_ASUS_M51VA), | 17217 | SND_PCI_QUIRK(0x1043, 0x17c3, "ASUS UX20", ALC663_ASUS_M51VA), |
| 16927 | SND_PCI_QUIRK(0x1043, 0x17f3, "ASUS X58LE", ALC662_ASUS_MODE2), | 17218 | SND_PCI_QUIRK(0x1043, 0x17f3, "ASUS X58LE", ALC662_ASUS_MODE2), |
| @@ -17205,6 +17496,36 @@ static struct alc_config_preset alc662_presets[] = { | |||
| 17205 | .setup = alc663_mode6_setup, | 17496 | .setup = alc663_mode6_setup, |
| 17206 | .init_hook = alc663_mode6_inithook, | 17497 | .init_hook = alc663_mode6_inithook, |
| 17207 | }, | 17498 | }, |
| 17499 | [ALC663_ASUS_MODE7] = { | ||
| 17500 | .mixers = { alc663_mode7_mixer }, | ||
| 17501 | .cap_mixer = alc662_auto_capture_mixer, | ||
| 17502 | .init_verbs = { alc662_init_verbs, | ||
| 17503 | alc663_mode7_init_verbs }, | ||
| 17504 | .num_dacs = ARRAY_SIZE(alc662_dac_nids), | ||
| 17505 | .hp_nid = 0x03, | ||
| 17506 | .dac_nids = alc662_dac_nids, | ||
| 17507 | .dig_out_nid = ALC662_DIGOUT_NID, | ||
| 17508 | .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes), | ||
| 17509 | .channel_mode = alc662_3ST_2ch_modes, | ||
| 17510 | .unsol_event = alc663_mode7_unsol_event, | ||
| 17511 | .setup = alc663_mode7_setup, | ||
| 17512 | .init_hook = alc663_mode7_inithook, | ||
| 17513 | }, | ||
| 17514 | [ALC663_ASUS_MODE8] = { | ||
| 17515 | .mixers = { alc663_mode8_mixer }, | ||
| 17516 | .cap_mixer = alc662_auto_capture_mixer, | ||
| 17517 | .init_verbs = { alc662_init_verbs, | ||
| 17518 | alc663_mode8_init_verbs }, | ||
| 17519 | .num_dacs = ARRAY_SIZE(alc662_dac_nids), | ||
| 17520 | .hp_nid = 0x03, | ||
| 17521 | .dac_nids = alc662_dac_nids, | ||
| 17522 | .dig_out_nid = ALC662_DIGOUT_NID, | ||
| 17523 | .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes), | ||
| 17524 | .channel_mode = alc662_3ST_2ch_modes, | ||
| 17525 | .unsol_event = alc663_mode8_unsol_event, | ||
| 17526 | .setup = alc663_mode8_setup, | ||
| 17527 | .init_hook = alc663_mode8_inithook, | ||
| 17528 | }, | ||
| 17208 | [ALC272_DELL] = { | 17529 | [ALC272_DELL] = { |
| 17209 | .mixers = { alc663_m51va_mixer }, | 17530 | .mixers = { alc663_m51va_mixer }, |
| 17210 | .cap_mixer = alc272_auto_capture_mixer, | 17531 | .cap_mixer = alc272_auto_capture_mixer, |
| @@ -17688,7 +18009,9 @@ static struct hda_codec_preset snd_hda_preset_realtek[] = { | |||
| 17688 | { .id = 0x10ec0267, .name = "ALC267", .patch = patch_alc268 }, | 18009 | { .id = 0x10ec0267, .name = "ALC267", .patch = patch_alc268 }, |
| 17689 | { .id = 0x10ec0268, .name = "ALC268", .patch = patch_alc268 }, | 18010 | { .id = 0x10ec0268, .name = "ALC268", .patch = patch_alc268 }, |
| 17690 | { .id = 0x10ec0269, .name = "ALC269", .patch = patch_alc269 }, | 18011 | { .id = 0x10ec0269, .name = "ALC269", .patch = patch_alc269 }, |
| 18012 | { .id = 0x10ec0270, .name = "ALC270", .patch = patch_alc269 }, | ||
| 17691 | { .id = 0x10ec0272, .name = "ALC272", .patch = patch_alc662 }, | 18013 | { .id = 0x10ec0272, .name = "ALC272", .patch = patch_alc662 }, |
| 18014 | { .id = 0x10ec0275, .name = "ALC275", .patch = patch_alc269 }, | ||
| 17692 | { .id = 0x10ec0861, .rev = 0x100340, .name = "ALC660", | 18015 | { .id = 0x10ec0861, .rev = 0x100340, .name = "ALC660", |
| 17693 | .patch = patch_alc861 }, | 18016 | .patch = patch_alc861 }, |
| 17694 | { .id = 0x10ec0660, .name = "ALC660-VD", .patch = patch_alc861vd }, | 18017 | { .id = 0x10ec0660, .name = "ALC660-VD", .patch = patch_alc861vd }, |
diff --git a/sound/pcmcia/pdaudiocf/pdaudiocf_pcm.c b/sound/pcmcia/pdaudiocf/pdaudiocf_pcm.c index d057e6489643..5cfa608823f7 100644 --- a/sound/pcmcia/pdaudiocf/pdaudiocf_pcm.c +++ b/sound/pcmcia/pdaudiocf/pdaudiocf_pcm.c | |||
| @@ -51,7 +51,7 @@ static int snd_pcm_alloc_vmalloc_buffer(struct snd_pcm_substream *subs, size_t s | |||
| 51 | return 0; /* already enough large */ | 51 | return 0; /* already enough large */ |
| 52 | vfree(runtime->dma_area); | 52 | vfree(runtime->dma_area); |
| 53 | } | 53 | } |
| 54 | runtime->dma_area = vmalloc_32(size); | 54 | runtime->dma_area = vmalloc_32_user(size); |
| 55 | if (! runtime->dma_area) | 55 | if (! runtime->dma_area) |
| 56 | return -ENOMEM; | 56 | return -ENOMEM; |
| 57 | runtime->dma_bytes = size; | 57 | runtime->dma_bytes = size; |
diff --git a/sound/soc/codecs/ak4642.c b/sound/soc/codecs/ak4642.c index b69861d52161..3ef16bbc8c83 100644 --- a/sound/soc/codecs/ak4642.c +++ b/sound/soc/codecs/ak4642.c | |||
| @@ -470,7 +470,7 @@ EXPORT_SYMBOL_GPL(soc_codec_dev_ak4642); | |||
| 470 | 470 | ||
| 471 | static int __init ak4642_modinit(void) | 471 | static int __init ak4642_modinit(void) |
| 472 | { | 472 | { |
| 473 | int ret; | 473 | int ret = 0; |
| 474 | #if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE) | 474 | #if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE) |
| 475 | ret = i2c_add_driver(&ak4642_i2c_driver); | 475 | ret = i2c_add_driver(&ak4642_i2c_driver); |
| 476 | #endif | 476 | #endif |
diff --git a/sound/soc/codecs/stac9766.c b/sound/soc/codecs/stac9766.c index bbc72c2ddfca..81b8c9dfe7fc 100644 --- a/sound/soc/codecs/stac9766.c +++ b/sound/soc/codecs/stac9766.c | |||
| @@ -191,6 +191,7 @@ static int ac97_analog_prepare(struct snd_pcm_substream *substream, | |||
| 191 | vra = stac9766_ac97_read(codec, AC97_EXTENDED_STATUS); | 191 | vra = stac9766_ac97_read(codec, AC97_EXTENDED_STATUS); |
| 192 | 192 | ||
| 193 | vra |= 0x1; /* enable variable rate audio */ | 193 | vra |= 0x1; /* enable variable rate audio */ |
| 194 | vra &= ~0x4; /* disable SPDIF output */ | ||
| 194 | 195 | ||
| 195 | stac9766_ac97_write(codec, AC97_EXTENDED_STATUS, vra); | 196 | stac9766_ac97_write(codec, AC97_EXTENDED_STATUS, vra); |
| 196 | 197 | ||
| @@ -221,22 +222,6 @@ static int ac97_digital_prepare(struct snd_pcm_substream *substream, | |||
| 221 | return stac9766_ac97_write(codec, reg, runtime->rate); | 222 | return stac9766_ac97_write(codec, reg, runtime->rate); |
| 222 | } | 223 | } |
| 223 | 224 | ||
| 224 | static int ac97_digital_trigger(struct snd_pcm_substream *substream, | ||
| 225 | int cmd, struct snd_soc_dai *dai) | ||
| 226 | { | ||
| 227 | struct snd_soc_codec *codec = dai->codec; | ||
| 228 | unsigned short vra; | ||
| 229 | |||
| 230 | switch (cmd) { | ||
| 231 | case SNDRV_PCM_TRIGGER_STOP: | ||
| 232 | vra = stac9766_ac97_read(codec, AC97_EXTENDED_STATUS); | ||
| 233 | vra &= !0x04; | ||
| 234 | stac9766_ac97_write(codec, AC97_EXTENDED_STATUS, vra); | ||
| 235 | break; | ||
| 236 | } | ||
| 237 | return 0; | ||
| 238 | } | ||
| 239 | |||
| 240 | static int stac9766_set_bias_level(struct snd_soc_codec *codec, | 225 | static int stac9766_set_bias_level(struct snd_soc_codec *codec, |
| 241 | enum snd_soc_bias_level level) | 226 | enum snd_soc_bias_level level) |
| 242 | { | 227 | { |
| @@ -315,7 +300,6 @@ static struct snd_soc_dai_ops stac9766_dai_ops_analog = { | |||
| 315 | 300 | ||
| 316 | static struct snd_soc_dai_ops stac9766_dai_ops_digital = { | 301 | static struct snd_soc_dai_ops stac9766_dai_ops_digital = { |
| 317 | .prepare = ac97_digital_prepare, | 302 | .prepare = ac97_digital_prepare, |
| 318 | .trigger = ac97_digital_trigger, | ||
| 319 | }; | 303 | }; |
| 320 | 304 | ||
| 321 | struct snd_soc_dai stac9766_dai[] = { | 305 | struct snd_soc_dai stac9766_dai[] = { |
diff --git a/sound/soc/codecs/wm8974.c b/sound/soc/codecs/wm8974.c index 81c57b5c591c..a808675388fc 100644 --- a/sound/soc/codecs/wm8974.c +++ b/sound/soc/codecs/wm8974.c | |||
| @@ -47,7 +47,7 @@ static const u16 wm8974_reg[WM8974_CACHEREGNUM] = { | |||
| 47 | }; | 47 | }; |
| 48 | 48 | ||
| 49 | #define WM8974_POWER1_BIASEN 0x08 | 49 | #define WM8974_POWER1_BIASEN 0x08 |
| 50 | #define WM8974_POWER1_BUFIOEN 0x10 | 50 | #define WM8974_POWER1_BUFIOEN 0x04 |
| 51 | 51 | ||
| 52 | struct wm8974_priv { | 52 | struct wm8974_priv { |
| 53 | struct snd_soc_codec codec; | 53 | struct snd_soc_codec codec; |
diff --git a/sound/usb/usbaudio.c b/sound/usb/usbaudio.c index b074a594c595..4963defee18a 100644 --- a/sound/usb/usbaudio.c +++ b/sound/usb/usbaudio.c | |||
| @@ -752,7 +752,7 @@ static int snd_pcm_alloc_vmalloc_buffer(struct snd_pcm_substream *subs, size_t s | |||
| 752 | return 0; /* already large enough */ | 752 | return 0; /* already large enough */ |
| 753 | vfree(runtime->dma_area); | 753 | vfree(runtime->dma_area); |
| 754 | } | 754 | } |
| 755 | runtime->dma_area = vmalloc(size); | 755 | runtime->dma_area = vmalloc_user(size); |
| 756 | if (!runtime->dma_area) | 756 | if (!runtime->dma_area) |
| 757 | return -ENOMEM; | 757 | return -ENOMEM; |
| 758 | runtime->dma_bytes = size; | 758 | runtime->dma_bytes = size; |
