abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 00:11 | Nová verze

    E-mailový klient Thunderbird byl vydán ve verzi 140.0 ESR „Eclipse“. Jde o vydání s dlouhodobou podporou, shrnující novinky v upozorněních, vzhledu, správě složek a správě účtů. Pozor, nezaměňovat s průběžným vydáním 140.0, které bylo dostupné o týden dříve.

    Fluttershy, yay! | Komentářů: 0
    včera 15:11 | IT novinky

    Organizace Video Games Europe reprezentující vydavatele počítačových her publikovala prohlášení k občanské iniciativě Stop Destroying Videogames.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | IT novinky

    Společnost Raspberry Pi nově nabzí Raspberry Pi Camera Module 3 Sensor Assembly, tj. samostatné senzorové moduly z Raspberry Pi Camera Module 3.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | Nasazení Linuxu

    Cathode Ray Dude v novém videu ukazuje autorádio Empeg Car (později Rio Car) z let 1999–2001. Šlo o jeden z prvních přehrávačů MP3 do auta. Běží na něm Linux. Vyrobeno bylo jen asi pět tisíc kusů, ale zůstala kolem nich živá komunita, viz např. web riocar.org.

    Fluttershy, yay! | Komentářů: 0
    včera 02:11 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.7.

    Ladislav Hagara | Komentářů: 0
    včera 01:44 | Nová verze

    Wayland byl vydán ve verzi 1.24.0. Jde o menší vydání po více než roce. Více funkcionality bývá přidáváno v průběžných vydáních Wayland Protocols.

    Fluttershy, yay! | Komentářů: 0
    6.7. 23:44 | Nová verze

    Textový editor Geany byl vydán ve verzi 2.1. Jde o udržovací vydání po bezmála dvou letech. Obsahuje drobná vylepšení vyhledávání, aktualizace podpory zvýrazňování syntaxe a dále převážně opravy chyb.

    Fluttershy, yay! | Komentářů: 1
    6.7. 19:44 | Komunita

    Byly zveřejněny videozáznamy, dostupné také s prezentacemi přímo z programu, a také fotogalerie z open source komunitní konference DevConf.CZ 2025 konané od 12. do 14. června v Brně.

    Ladislav Hagara | Komentářů: 0
    5.7. 20:22 | Zajímavý software

    Navigace se soukromím CoMaps postavena nad OpenStreetMap je nově k dispozici v Google Play, App Store i F-Droid. Jedná se o komunitní fork aplikace Organic Maps.

    Ladislav Hagara | Komentářů: 8
    4.7. 19:33 | Nová verze

    Vývojáři OpenMW (Wikipedie) oznámili vydání verze 0.49.0 této svobodné implementace enginu pro hru The Elder Scrolls III: Morrowind. Přehled novinek i s náhledy obrazovek v oznámení o vydání.

    Ladislav Hagara | Komentářů: 1
    Jaký je váš oblíbený skriptovací jazyk?
     (60%)
     (27%)
     (7%)
     (2%)
     (1%)
     (1%)
     (3%)
    Celkem 367 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Siemens MC45

    Podpora: kompletní
    Ovladač: dodává někdo jiný

    Technické parametry

     

    Identifikace pod Linuxem

    ttyS14 at I/O 0x400 (irq = 3) is a 16C950/954

    Postup zprovoznění pod Linuxem

    Petr Vandrovec napsal patch a postnul jej do linux kernel mailing listu.

     

    Je tam napsany i navod na zprovozneni.

    (Smyslem patche je probudit MC45 ze sleep módu, ve kterém se nachází po startu. Jiná možnost, jak MC45 probudit je něj zavolat z jiného telefonu; to samozřejmě lze použít pouze k otestování funkčnosti bez nutnosti hned patchovat jádro, nikoliv k běžnému použití...)

    Poznámka

    1) Patch funguje a karta prijima AT prikazy na vanilla jadrech. Aplikovat patch do kernelu FC3 slo, ale karta nebezela. Podobnou zkusenost meli lidi i s MDK jadry.

     

    2) Nevim jestli je nekde archiv lkml v plain textu a tak jsem ten patch vykousany z html dal sem.

     

    3) Spojeni k inetu nahazuju takto:

    rm /dev/modem &>/dev/null
    ln -s /dev/ttyS14 /dev/modem >/dev/null
    setserial -bG /dev/modem baud_base 1152000 &>/dev/null
    nohup wvdial &>/dev/null &
    

    4) cat /etc/wvdial.conf

    [Dialer Defaults]
    Modem = /dev/modem
    Baud = 57600
    Init1 = ATZ
    Init2 = AT+CGDCONT=1,"IP","INTERNET"
    Init3 =
    Area Code =
    Phone = *99***1#
    Username = internet
    Password = none
    Ask Password = 0
    Dial Command = ATDT
    Stupid Mode = 1
    Compuserve = 0
    Force Address =
    Idle Seconds = 0
    DialMessage1 =
    DialMessage2 =
    ISDN = 0
    Auto DNS = 1
    

     

    Protože patch na Jikosových stránkách už není, dovolil jsem si ho přetisknout:

    diff -urN linux/include/pcmcia/ciscode.h linux/include/pcmcia/ciscode.h
     --- linux/include/pcmcia/ciscode.h 2004-08-28 23:21:03.000000000 +0200
     +++ linux/include/pcmcia/ciscode.h 2004-08-28 23:36:24.000000000 +0200
     @@ -135,4 +135,7 @@
     
     #define MANFID_XIRCOM 0x0105
     
     +#define MANFID_POSSIO 0x030c
     +#define PRODID_POSSIO_GCC 0x0003
     +
     #endif /* _LINUX_CISCODE_H */
     diff -urN linux/drivers/serial/serial_cs.c linux/drivers/serial/serial_cs.c
     --- linux/drivers/serial/serial_cs.c 2004-08-28 23:19:58.000000000 +0200
     +++ linux/drivers/serial/serial_cs.c 2004-08-30 02:53:05.000000000 +0200
     @@ -44,6 +44,7 @@
     #include <linux/serial.h>
     #include <linux/serial_core.h>
     #include <linux/major.h>
     +#include <linux/delay.h>
     #include <asm/io.h>
     #include <asm/system.h>
     
     @@ -112,6 +113,8 @@
     int multi;
     int slave;
     int manfid;
     + int prodid;
     + int c950ctrl;
     dev_node_t node[4];
     int line[4];
     };
     @@ -127,6 +130,33 @@
     
     static dev_link_t *dev_list = NULL;
     
     +static void wakeup_card(struct serial_info *info)
     +{
     + int ctrl = info->c950ctrl;
     +
     + if (info->manfid == MANFID_OXSEMI) {
     + outb(12, ctrl + 1);
     + } else if (info->manfid == MANFID_POSSIO && info->prodid == PRODID_POSSIO_GCC) {
     + /* request_region? oxsemi branch does no request_region too... */
     + /* This sequence is needed to properly initialize MC45 attached to OXCF950.
     + * I tried decreasing these msleep()s, but it worked properly (survived
     + * 1000 stop/start operations) with these timeouts (or bigger). */
     + outb(0xA, ctrl + 1);
     + msleep(100);
     + outb(0xE, ctrl + 1);
     + msleep(300);
     + outb(0xC, ctrl + 1);
     + msleep(100);
     + outb(0xE, ctrl + 1);
     + msleep(200);
     + outb(0xF, ctrl + 1);
     + msleep(100);
     + outb(0xE, ctrl + 1);
     + msleep(100);
     + outb(0xC, ctrl + 1);
     + }
     +}
     +
     /*======================================================================
     
     After a card is removed, serial_remove() will unregister
     @@ -191,6 +221,7 @@
     
     for (i = 0; i < info->ndev; i++)
     serial8250_resume_port(info->line[i]);
     + wakeup_card(info);
     }
     }
     
     @@ -554,15 +585,20 @@
     }
     
     /* The Oxford Semiconductor OXCF950 cards are in fact single-port:
     - 8 registers are for the UART, the others are extra registers */
     - if (info->manfid == MANFID_OXSEMI) {
     + 8 registers are for the UART, the others are extra registers.
     + Siemen's MC45 PCMCIA (Possio's GCC) is OXCF950 based too. */
     + if (info->manfid == MANFID_OXSEMI ||
     + (info->manfid == MANFID_POSSIO && info->prodid == PRODID_POSSIO_GCC)) {
     + int err;
     +
     if (cf->index == 1 || cf->index == 3) {
     - setup_serial(info, base2, link->irq.AssignedIRQ);
     - outb(12, link->io.BasePort1 + 1);
     + err = setup_serial(info, base2, link->irq.AssignedIRQ);
     + base2 = link->io.BasePort1;
     } else {
     - setup_serial(info, link->io.BasePort1, link->irq.AssignedIRQ);
     - outb(12, base2 + 1);
     + err = setup_serial(info, link->io.BasePort1, link->irq.AssignedIRQ);
     }
     + info->c950ctrl = base2;
     + wakeup_card(info);
     return 0;
     }
     
     @@ -622,9 +658,10 @@
     tuple.DesiredTuple = CISTPL_MANFID;
     if (first_tuple(handle, &tuple, &parse) == CS_SUCCESS) {
     info->manfid = le16_to_cpu(buf[0]);
     + info->prodid = le16_to_cpu(buf[1]);
     for (i = 0; i < MULTI_COUNT; i++)
     if ((info->manfid == multi_id[i].manfid) &&
     - (le16_to_cpu(buf[1]) == multi_id[i].prodid))
     + (info->prodid == multi_id[i].prodid))
     break;
     if (i < MULTI_COUNT)
     info->multi = multi_id[i].multi;
    

    Dokument vytvořil: tomaso, 4.11.2004 08:50 | Poslední úprava: Petr Tomášek, 27.2.2011 15:07 | Další přispěvatelé: Bluebear | Historie změn | Zobrazeno: 1458×

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.