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í
×
    včera 07:33 | Komunita

    O víkendu probíhá konference OpenAlt 2025. Na programu je spousta zajímavých přednášek. Pokud jste v Brně, stavte se. Vstup zdarma.

    Ladislav Hagara | Komentářů: 0
    včera 00:55 | IT novinky

    Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.

    Ladislav Hagara | Komentářů: 7
    31.10. 18:33 | IT novinky

    Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).

    Ladislav Hagara | Komentářů: 0
    31.10. 13:22 | Komunita

    Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).

    Ladislav Hagara | Komentářů: 8
    31.10. 01:22 | Nová verze

    Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    31.10. 00:11 | IT novinky

    Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.

    Ladislav Hagara | Komentářů: 5
    30.10. 23:44 | Komunita

    Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.

    Ladislav Hagara | Komentářů: 0
    30.10. 15:22 | Nová verze

    Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 2
    30.10. 12:55 | Nová verze

    Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).

    Ladislav Hagara | Komentářů: 1
    30.10. 02:55 | Nová verze

    Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (19%)
     (19%)
     (23%)
     (16%)
     (20%)
     (16%)
     (17%)
    Celkem 297 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    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: 1471×

    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.