diff options
Diffstat (limited to 'drivers/media/common')
| -rw-r--r-- | drivers/media/common/Kconfig | 4 | ||||
| -rw-r--r-- | drivers/media/common/ir-functions.c | 110 | ||||
| -rw-r--r-- | drivers/media/common/ir-keymaps.c | 171 | ||||
| -rw-r--r-- | drivers/media/common/saa7146_fops.c | 2 |
4 files changed, 282 insertions, 5 deletions
diff --git a/drivers/media/common/Kconfig b/drivers/media/common/Kconfig index f33e5d973413..c120114c241b 100644 --- a/drivers/media/common/Kconfig +++ b/drivers/media/common/Kconfig | |||
| @@ -5,8 +5,4 @@ config VIDEO_SAA7146 | |||
| 5 | config VIDEO_SAA7146_VV | 5 | config VIDEO_SAA7146_VV |
| 6 | tristate | 6 | tristate |
| 7 | select VIDEO_BUF | 7 | select VIDEO_BUF |
| 8 | select VIDEO_VIDEOBUF | ||
| 9 | select VIDEO_SAA7146 | 8 | select VIDEO_SAA7146 |
| 10 | |||
| 11 | config VIDEO_VIDEOBUF | ||
| 12 | tristate | ||
diff --git a/drivers/media/common/ir-functions.c b/drivers/media/common/ir-functions.c index 9a8dd8764c99..cbf7c0564889 100644 --- a/drivers/media/common/ir-functions.c +++ b/drivers/media/common/ir-functions.c | |||
| @@ -256,6 +256,112 @@ int ir_decode_biphase(u32 *samples, int count, int low, int high) | |||
| 256 | return value; | 256 | return value; |
| 257 | } | 257 | } |
| 258 | 258 | ||
| 259 | /* RC5 decoding stuff, moved from bttv-input.c to share it with | ||
| 260 | * saa7134 */ | ||
| 261 | |||
| 262 | /* decode raw bit pattern to RC5 code */ | ||
| 263 | u32 ir_rc5_decode(unsigned int code) | ||
| 264 | { | ||
| 265 | unsigned int org_code = code; | ||
| 266 | unsigned int pair; | ||
| 267 | unsigned int rc5 = 0; | ||
| 268 | int i; | ||
| 269 | |||
| 270 | for (i = 0; i < 14; ++i) { | ||
| 271 | pair = code & 0x3; | ||
| 272 | code >>= 2; | ||
| 273 | |||
| 274 | rc5 <<= 1; | ||
| 275 | switch (pair) { | ||
| 276 | case 0: | ||
| 277 | case 2: | ||
| 278 | break; | ||
| 279 | case 1: | ||
| 280 | rc5 |= 1; | ||
| 281 | break; | ||
| 282 | case 3: | ||
| 283 | dprintk(1, "ir-common: ir_rc5_decode(%x) bad code\n", org_code); | ||
| 284 | return 0; | ||
| 285 | } | ||
| 286 | } | ||
| 287 | dprintk(1, "ir-common: code=%x, rc5=%x, start=%x, toggle=%x, address=%x, " | ||
| 288 | "instr=%x\n", rc5, org_code, RC5_START(rc5), | ||
| 289 | RC5_TOGGLE(rc5), RC5_ADDR(rc5), RC5_INSTR(rc5)); | ||
| 290 | return rc5; | ||
| 291 | } | ||
| 292 | |||
| 293 | void ir_rc5_timer_end(unsigned long data) | ||
| 294 | { | ||
| 295 | struct card_ir *ir = (struct card_ir *)data; | ||
| 296 | struct timeval tv; | ||
| 297 | unsigned long current_jiffies, timeout; | ||
| 298 | u32 gap; | ||
| 299 | u32 rc5 = 0; | ||
| 300 | |||
| 301 | /* get time */ | ||
| 302 | current_jiffies = jiffies; | ||
| 303 | do_gettimeofday(&tv); | ||
| 304 | |||
| 305 | /* avoid overflow with gap >1s */ | ||
| 306 | if (tv.tv_sec - ir->base_time.tv_sec > 1) { | ||
| 307 | gap = 200000; | ||
| 308 | } else { | ||
| 309 | gap = 1000000 * (tv.tv_sec - ir->base_time.tv_sec) + | ||
| 310 | tv.tv_usec - ir->base_time.tv_usec; | ||
| 311 | } | ||
| 312 | |||
| 313 | /* Allow some timmer jitter (RC5 is ~24ms anyway so this is ok) */ | ||
| 314 | if (gap < 28000) { | ||
| 315 | dprintk(1, "ir-common: spurious timer_end\n"); | ||
| 316 | return; | ||
| 317 | } | ||
| 318 | |||
| 319 | ir->active = 0; | ||
| 320 | if (ir->last_bit < 20) { | ||
| 321 | /* ignore spurious codes (caused by light/other remotes) */ | ||
| 322 | dprintk(1, "ir-common: short code: %x\n", ir->code); | ||
| 323 | } else { | ||
| 324 | ir->code = (ir->code << ir->shift_by) | 1; | ||
| 325 | rc5 = ir_rc5_decode(ir->code); | ||
| 326 | |||
| 327 | /* two start bits? */ | ||
| 328 | if (RC5_START(rc5) != ir->start) { | ||
| 329 | dprintk(1, "ir-common: rc5 start bits invalid: %u\n", RC5_START(rc5)); | ||
| 330 | |||
| 331 | /* right address? */ | ||
| 332 | } else if (RC5_ADDR(rc5) == ir->addr) { | ||
| 333 | u32 toggle = RC5_TOGGLE(rc5); | ||
| 334 | u32 instr = RC5_INSTR(rc5); | ||
| 335 | |||
| 336 | /* Good code, decide if repeat/repress */ | ||
| 337 | if (toggle != RC5_TOGGLE(ir->last_rc5) || | ||
| 338 | instr != RC5_INSTR(ir->last_rc5)) { | ||
| 339 | dprintk(1, "ir-common: instruction %x, toggle %x\n", instr, | ||
| 340 | toggle); | ||
| 341 | ir_input_nokey(ir->dev, &ir->ir); | ||
| 342 | ir_input_keydown(ir->dev, &ir->ir, instr, | ||
| 343 | instr); | ||
| 344 | } | ||
| 345 | |||
| 346 | /* Set/reset key-up timer */ | ||
| 347 | timeout = current_jiffies + (500 + ir->rc5_key_timeout | ||
| 348 | * HZ) / 1000; | ||
| 349 | mod_timer(&ir->timer_keyup, timeout); | ||
| 350 | |||
| 351 | /* Save code for repeat test */ | ||
| 352 | ir->last_rc5 = rc5; | ||
| 353 | } | ||
| 354 | } | ||
| 355 | } | ||
| 356 | |||
| 357 | void ir_rc5_timer_keyup(unsigned long data) | ||
| 358 | { | ||
| 359 | struct card_ir *ir = (struct card_ir *)data; | ||
| 360 | |||
| 361 | dprintk(1, "ir-common: key released\n"); | ||
| 362 | ir_input_nokey(ir->dev, &ir->ir); | ||
| 363 | } | ||
| 364 | |||
| 259 | EXPORT_SYMBOL_GPL(ir_input_init); | 365 | EXPORT_SYMBOL_GPL(ir_input_init); |
| 260 | EXPORT_SYMBOL_GPL(ir_input_nokey); | 366 | EXPORT_SYMBOL_GPL(ir_input_nokey); |
| 261 | EXPORT_SYMBOL_GPL(ir_input_keydown); | 367 | EXPORT_SYMBOL_GPL(ir_input_keydown); |
| @@ -265,6 +371,10 @@ EXPORT_SYMBOL_GPL(ir_dump_samples); | |||
| 265 | EXPORT_SYMBOL_GPL(ir_decode_biphase); | 371 | EXPORT_SYMBOL_GPL(ir_decode_biphase); |
| 266 | EXPORT_SYMBOL_GPL(ir_decode_pulsedistance); | 372 | EXPORT_SYMBOL_GPL(ir_decode_pulsedistance); |
| 267 | 373 | ||
| 374 | EXPORT_SYMBOL_GPL(ir_rc5_decode); | ||
| 375 | EXPORT_SYMBOL_GPL(ir_rc5_timer_end); | ||
| 376 | EXPORT_SYMBOL_GPL(ir_rc5_timer_keyup); | ||
| 377 | |||
| 268 | /* | 378 | /* |
| 269 | * Local variables: | 379 | * Local variables: |
| 270 | * c-basic-offset: 8 | 380 | * c-basic-offset: 8 |
diff --git a/drivers/media/common/ir-keymaps.c b/drivers/media/common/ir-keymaps.c index 0e948a5c5a03..03b47a262f27 100644 --- a/drivers/media/common/ir-keymaps.c +++ b/drivers/media/common/ir-keymaps.c | |||
| @@ -1606,3 +1606,174 @@ IR_KEYTAB_TYPE ir_codes_budget_ci_old[IR_KEYTAB_SIZE] = { | |||
| 1606 | }; | 1606 | }; |
| 1607 | 1607 | ||
| 1608 | EXPORT_SYMBOL_GPL(ir_codes_budget_ci_old); | 1608 | EXPORT_SYMBOL_GPL(ir_codes_budget_ci_old); |
| 1609 | |||
| 1610 | /* | ||
| 1611 | * Marc Fargas <telenieko@telenieko.com> | ||
| 1612 | * this is the remote control that comes with the asus p7131 | ||
| 1613 | * which has a label saying is "Model PC-39" | ||
| 1614 | */ | ||
| 1615 | IR_KEYTAB_TYPE ir_codes_asus_pc39[IR_KEYTAB_SIZE] = { | ||
| 1616 | /* Keys 0 to 9 */ | ||
| 1617 | [ 0x15 ] = KEY_0, | ||
| 1618 | [ 0x29 ] = KEY_1, | ||
| 1619 | [ 0x2d ] = KEY_2, | ||
| 1620 | [ 0x2b ] = KEY_3, | ||
| 1621 | [ 0x09 ] = KEY_4, | ||
| 1622 | [ 0x0d ] = KEY_5, | ||
| 1623 | [ 0x0b ] = KEY_6, | ||
| 1624 | [ 0x31 ] = KEY_7, | ||
| 1625 | [ 0x35 ] = KEY_8, | ||
| 1626 | [ 0x33 ] = KEY_9, | ||
| 1627 | |||
| 1628 | [ 0x3e ] = KEY_RADIO, /* radio */ | ||
| 1629 | [ 0x03 ] = KEY_MENU, /* dvd/menu */ | ||
| 1630 | [ 0x2a ] = KEY_VOLUMEUP, | ||
| 1631 | [ 0x19 ] = KEY_VOLUMEDOWN, | ||
| 1632 | [ 0x37 ] = KEY_UP, | ||
| 1633 | [ 0x3b ] = KEY_DOWN, | ||
| 1634 | [ 0x27 ] = KEY_LEFT, | ||
| 1635 | [ 0x2f ] = KEY_RIGHT, | ||
| 1636 | [ 0x25 ] = KEY_VIDEO, /* video */ | ||
| 1637 | [ 0x39 ] = KEY_AUDIO, /* music */ | ||
| 1638 | |||
| 1639 | [ 0x21 ] = KEY_TV, /* tv */ | ||
| 1640 | [ 0x1d ] = KEY_EXIT, /* back */ | ||
| 1641 | [ 0x0a ] = KEY_CHANNELUP, /* channel / program + */ | ||
| 1642 | [ 0x1b ] = KEY_CHANNELDOWN, /* channel / program - */ | ||
| 1643 | [ 0x1a ] = KEY_ENTER, /* enter */ | ||
| 1644 | |||
| 1645 | [ 0x06 ] = KEY_PAUSE, /* play/pause */ | ||
| 1646 | [ 0x1e ] = KEY_PREVIOUS, /* rew */ | ||
| 1647 | [ 0x26 ] = KEY_NEXT, /* forward */ | ||
| 1648 | [ 0x0e ] = KEY_REWIND, /* backward << */ | ||
| 1649 | [ 0x3a ] = KEY_FASTFORWARD, /* forward >> */ | ||
| 1650 | [ 0x36 ] = KEY_STOP, | ||
| 1651 | [ 0x2e ] = KEY_RECORD, /* recording */ | ||
| 1652 | [ 0x16 ] = KEY_POWER, /* the button that reads "close" */ | ||
| 1653 | |||
| 1654 | [ 0x11 ] = KEY_ZOOM, /* full screen */ | ||
| 1655 | [ 0x13 ] = KEY_MACRO, /* recall */ | ||
| 1656 | [ 0x23 ] = KEY_HOME, /* home */ | ||
| 1657 | [ 0x05 ] = KEY_PVR, /* picture */ | ||
| 1658 | [ 0x3d ] = KEY_MUTE, /* mute */ | ||
| 1659 | [ 0x01 ] = KEY_DVD, /* dvd */ | ||
| 1660 | }; | ||
| 1661 | |||
| 1662 | EXPORT_SYMBOL_GPL(ir_codes_asus_pc39); | ||
| 1663 | |||
| 1664 | |||
| 1665 | /* Encore ENLTV-FM - black plastic, white front cover with white glowing buttons | ||
| 1666 | Juan Pablo Sormani <sorman@gmail.com> */ | ||
| 1667 | IR_KEYTAB_TYPE ir_codes_encore_enltv[IR_KEYTAB_SIZE] = { | ||
| 1668 | |||
| 1669 | /* Power button does nothing, neither in Windows app, | ||
| 1670 | although it sends data (used for BIOS wakeup?) */ | ||
| 1671 | [ 0x0d ] = KEY_MUTE, | ||
| 1672 | |||
| 1673 | [ 0x1e ] = KEY_TV, | ||
| 1674 | [ 0x00 ] = KEY_VIDEO, | ||
| 1675 | [ 0x01 ] = KEY_AUDIO, /* music */ | ||
| 1676 | [ 0x02 ] = KEY_MHP, /* picture */ | ||
| 1677 | |||
| 1678 | [ 0x1f ] = KEY_1, | ||
| 1679 | [ 0x03 ] = KEY_2, | ||
| 1680 | [ 0x04 ] = KEY_3, | ||
| 1681 | [ 0x05 ] = KEY_4, | ||
| 1682 | [ 0x1c ] = KEY_5, | ||
| 1683 | [ 0x06 ] = KEY_6, | ||
| 1684 | [ 0x07 ] = KEY_7, | ||
| 1685 | [ 0x08 ] = KEY_8, | ||
| 1686 | [ 0x1d ] = KEY_9, | ||
| 1687 | [ 0x0a ] = KEY_0, | ||
| 1688 | |||
| 1689 | [ 0x09 ] = KEY_LIST, /* -/-- */ | ||
| 1690 | [ 0x0b ] = KEY_LAST, /* recall */ | ||
| 1691 | |||
| 1692 | [ 0x14 ] = KEY_HOME, /* win start menu */ | ||
| 1693 | [ 0x15 ] = KEY_EXIT, /* exit */ | ||
| 1694 | [ 0x16 ] = KEY_UP, | ||
| 1695 | [ 0x12 ] = KEY_DOWN, | ||
| 1696 | [ 0x0c ] = KEY_RIGHT, | ||
| 1697 | [ 0x17 ] = KEY_LEFT, | ||
| 1698 | |||
| 1699 | [ 0x18 ] = KEY_ENTER, /* OK */ | ||
| 1700 | |||
| 1701 | [ 0x0e ] = KEY_ESC, | ||
| 1702 | [ 0x13 ] = KEY_D, /* desktop */ | ||
| 1703 | [ 0x11 ] = KEY_TAB, | ||
| 1704 | [ 0x19 ] = KEY_SWITCHVIDEOMODE, /* switch */ | ||
| 1705 | |||
| 1706 | [ 0x1a ] = KEY_MENU, | ||
| 1707 | [ 0x1b ] = KEY_ZOOM, /* fullscreen */ | ||
| 1708 | [ 0x44 ] = KEY_TIME, /* time shift */ | ||
| 1709 | [ 0x40 ] = KEY_MODE, /* source */ | ||
| 1710 | |||
| 1711 | [ 0x5a ] = KEY_RECORD, | ||
| 1712 | [ 0x42 ] = KEY_PLAY, /* play/pause */ | ||
| 1713 | [ 0x45 ] = KEY_STOP, | ||
| 1714 | [ 0x43 ] = KEY_CAMERA, /* camera icon */ | ||
| 1715 | |||
| 1716 | [ 0x48 ] = KEY_REWIND, | ||
| 1717 | [ 0x4a ] = KEY_FASTFORWARD, | ||
| 1718 | [ 0x49 ] = KEY_PREVIOUS, | ||
| 1719 | [ 0x4b ] = KEY_NEXT, | ||
| 1720 | |||
| 1721 | [ 0x4c ] = KEY_FAVORITES, /* tv wall */ | ||
| 1722 | [ 0x4d ] = KEY_SOUND, /* DVD sound */ | ||
| 1723 | [ 0x4e ] = KEY_LANGUAGE, /* DVD lang */ | ||
| 1724 | [ 0x4f ] = KEY_TEXT, /* DVD text */ | ||
| 1725 | |||
| 1726 | [ 0x50 ] = KEY_SLEEP, /* shutdown */ | ||
| 1727 | [ 0x51 ] = KEY_MODE, /* stereo > main */ | ||
| 1728 | [ 0x52 ] = KEY_SELECT, /* stereo > sap */ | ||
| 1729 | [ 0x53 ] = KEY_PROG1, /* teletext */ | ||
| 1730 | |||
| 1731 | |||
| 1732 | [ 0x59 ] = KEY_RED, /* AP1 */ | ||
| 1733 | [ 0x41 ] = KEY_GREEN, /* AP2 */ | ||
| 1734 | [ 0x47 ] = KEY_YELLOW, /* AP3 */ | ||
| 1735 | [ 0x57 ] = KEY_BLUE, /* AP4 */ | ||
| 1736 | |||
| 1737 | |||
| 1738 | }; | ||
| 1739 | |||
| 1740 | EXPORT_SYMBOL_GPL(ir_codes_encore_enltv); | ||
| 1741 | |||
| 1742 | /* for the Technotrend 1500 bundled remote: */ | ||
| 1743 | IR_KEYTAB_TYPE ir_codes_tt_1500[IR_KEYTAB_SIZE] = { | ||
| 1744 | [ 0x01 ] = KEY_POWER, | ||
| 1745 | [ 0x02 ] = KEY_SHUFFLE, /* ? double-arrow key */ | ||
| 1746 | [ 0x03 ] = KEY_1, | ||
| 1747 | [ 0x04 ] = KEY_2, | ||
| 1748 | [ 0x05 ] = KEY_3, | ||
| 1749 | [ 0x06 ] = KEY_4, | ||
| 1750 | [ 0x07 ] = KEY_5, | ||
| 1751 | [ 0x08 ] = KEY_6, | ||
| 1752 | [ 0x09 ] = KEY_7, | ||
| 1753 | [ 0x0a ] = KEY_8, | ||
| 1754 | [ 0x0b ] = KEY_9, | ||
| 1755 | [ 0x0c ] = KEY_0, | ||
| 1756 | [ 0x0d ] = KEY_UP, | ||
| 1757 | [ 0x0e ] = KEY_LEFT, | ||
| 1758 | [ 0x0f ] = KEY_OK, | ||
| 1759 | [ 0x10 ] = KEY_RIGHT, | ||
| 1760 | [ 0x11 ] = KEY_DOWN, | ||
| 1761 | [ 0x12 ] = KEY_INFO, | ||
| 1762 | [ 0x13 ] = KEY_EXIT, | ||
| 1763 | [ 0x14 ] = KEY_RED, | ||
| 1764 | [ 0x15 ] = KEY_GREEN, | ||
| 1765 | [ 0x16 ] = KEY_YELLOW, | ||
| 1766 | [ 0x17 ] = KEY_BLUE, | ||
| 1767 | [ 0x18 ] = KEY_MUTE, | ||
| 1768 | [ 0x19 ] = KEY_TEXT, | ||
| 1769 | [ 0x1a ] = KEY_MODE, /* ? TV/Radio */ | ||
| 1770 | [ 0x21 ] = KEY_OPTION, | ||
| 1771 | [ 0x22 ] = KEY_EPG, | ||
| 1772 | [ 0x23 ] = KEY_CHANNELUP, | ||
| 1773 | [ 0x24 ] = KEY_CHANNELDOWN, | ||
| 1774 | [ 0x25 ] = KEY_VOLUMEUP, | ||
| 1775 | [ 0x26 ] = KEY_VOLUMEDOWN, | ||
| 1776 | [ 0x27 ] = KEY_SETUP, | ||
| 1777 | }; | ||
| 1778 | |||
| 1779 | EXPORT_SYMBOL_GPL(ir_codes_tt_1500); | ||
diff --git a/drivers/media/common/saa7146_fops.c b/drivers/media/common/saa7146_fops.c index b8dcfa165266..c18a5da64934 100644 --- a/drivers/media/common/saa7146_fops.c +++ b/drivers/media/common/saa7146_fops.c | |||
| @@ -508,7 +508,7 @@ int saa7146_vv_release(struct saa7146_dev* dev) | |||
| 508 | 508 | ||
| 509 | DEB_EE(("dev:%p\n",dev)); | 509 | DEB_EE(("dev:%p\n",dev)); |
| 510 | 510 | ||
| 511 | pci_free_consistent(dev->pci, SAA7146_RPS_MEM, vv->d_clipping.cpu_addr, vv->d_clipping.dma_handle); | 511 | pci_free_consistent(dev->pci, SAA7146_CLIPPING_MEM, vv->d_clipping.cpu_addr, vv->d_clipping.dma_handle); |
| 512 | kfree(vv); | 512 | kfree(vv); |
| 513 | dev->vv_data = NULL; | 513 | dev->vv_data = NULL; |
| 514 | dev->vv_callback = NULL; | 514 | dev->vv_callback = NULL; |
