Byla vydána nová verze 2025.4 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení na blogu.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) zveřejnil Národní politiku koordinovaného zveřejňování zranitelností (pdf), jejímž cílem je nejen zvyšování bezpečnosti produktů informačních a komunikačních technologií (ICT), ale také ochrana objevitelů zranitelností před negativními právními dopady. Součástí je rovněž vytvoření „koordinátora pro účely CVD“, jímž je podle nového zákona o kybernetické … více »
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.12. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Společnost System76 vydala Pop!_OS 24.04 LTS s desktopovým prostředím COSMIC. Videoukázky na YouTube.
Byla vydána verze 1.92.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.
Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2024. Oceněni byli Andy Wingo, jeden ze správců GNU Guile, Alx Sa za příspěvky do Gimpu a Govdirectory jako společensky prospěšný projekt.
Bylo vydáno Eclipse IDE 2025-12 aneb Eclipse 4.38. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
U příležitosti oslav osmi let prací na debianím balíčku vyšlo GPXSee 15.6. Nová verze přináší především podporu pro geotagované MP4 soubory, včetně GoPro videí. Kdo nechce čekat, až nová verze dorazí do jeho distribuce, nalezne zdrojové kódy na GitHubu.
Monado, tj. multiplatformní open source implementace standardu OpenXR specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro virtuální realitu (VR) a rozšířenou realitu (AR), bylo vydáno ve verzi 25.1.0. Přehled novinek v poznámkách k vydání.
Byla vydána listopadová aktualizace aneb nová verze 1.107 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.107 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
echo ahoj > /dev/ttyS2 tak potom jinde v konsoli dam cat /dev/ttyS2. Ale ten cat vypisuje porad dokola prazdne radky a obcas se tam objevi to ahoj i kdyz jsem ho poslal jen jednou. Myslim si ze mam neco blbe v kernelu ale netusim co. Nevite nekdo co s tim? Dik Vojta
cat /dev/ttyS2 se zapnou vsechny ale ja bych je chtel zapnout zvlast. Diky Vojta
#include <sys/ioctl.h>
#include <fcntl.h>
#include <unistd.h>
int main(int argc, char **argv) {
int fd;
int iFlags = TIOCM_DTR;
fd = open("/dev/ttyS0", O_RDWR | O_SYNC);
ioctl(fd, TIOCMBIC, &iFlags); /* Vynuluje DTR */
ioctl(fd, TIOCMBIS, &iFlags); /* Nastavi DTR */
close(fd);
return 0;
}
Proste aby to umelo nastavovat vystupy seriaku. Diky moc Vojta
staci ti jen toto
http://www.linuxsoft.cz/article.php?id_article=387
usage: setdtrrts.py [options]
options:
--version show program's version number and exit
-h, --help show this help message and exit
-d DEVICE, --device=DEVICE
serial port device (default /dev/ttyS0)
-R, --RTS set RTS
-D, --DTR set DTR
-t DELAY, --time=DELAY
time in seconds to quit (default 5)
Takže například
setdtrrts.py -d /dev/ttyS1 --RTS --DTR -t 3Zapne obě stavové linky u portu /dev/ttyS1 na dobu tří sekund. A tady je ten program:
#!/usr/bin/env python
import tty, os, fcntl, time, struct
from optparse import OptionParser
usage = "usage: %prog [options]"
parser = OptionParser(usage, version="%prog version 0.1")
parser.add_option("-d", "--device", action = "store",
default = "/dev/ttyS0", dest="device", help="serial port device (default /dev/ttyS0)")
parser.add_option("-R", "--RTS", action = "store_true",
default = False, dest="rts", help="set RTS")
parser.add_option("-D", "--DTR", action = "store_true",
default = False, dest="dtr", help="set DTR")
parser.add_option("-t", "--time", action = "store", type = "float",
default = 5, dest="delay", help="time in seconds to quit (default 5)")
(options, args) = parser.parse_args()
TIOCM_DTR_str = struct.pack('I', tty.TIOCM_DTR)
TIOCM_RTS_str = struct.pack('I', tty.TIOCM_RTS)
fd = os.open(options.device, os.O_RDWR | os.O_SYNC)
if options.dtr:
print "setting DTR"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_DTR_str)
else:
print "clearing DTR"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_DTR_str)
if options.rts:
print "setting RTS"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_RTS_str)
else:
print "clearing RTS"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_RTS_str)
time.sleep(options.delay)
... a měl bys začít programovat v nějakém kloudném programovacím jazyce, který není odkázaný na volání externích programů.
. Ten docela ovladam(alespon si to myslim). Ale v linuxu co napriklad? C nebo Python? C mi prijde dost tezky. Dik za pomoc Vojta
). Dik moc Vojta
#!/usr/bin/env python
import tty, os, fcntl, time, struct, subprocess
programname = 'date'
delay = 3
TIOCM_DTR_str = struct.pack('I', tty.TIOCM_DTR)
TIOCM_RTS_str = struct.pack('I', tty.TIOCM_RTS)
fd = os.open('/dev/ttyS0', os.O_RDWR | os.O_SYNC)
while True:
print "setting DTR"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_DTR_str)
print "setting RTS"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_RTS_str)
subprocess.Popen([programname])
time.sleep(delay)
print "clearing DTR"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_DTR_str)
print "clearing RTS"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_RTS_str)
subprocess.Popen([programname])
time.sleep(delay)
#!/usr/bin/env python
import tty, os, fcntl, time, struct, subprocess
def runcommand(command):
process = subprocess.Popen([command])
process.wait()
def wait_period(period):
sec = time.time()
time_to_wait = period - sec % period
print "Waiting for %g seconds" %time_to_wait
time.sleep(time_to_wait)
class Relay:
def __init__(self, devpath, initstate = True):
self.fd = os.open(devpath, os.O_RDWR | os.O_SYNC)
self.TIOCM_DTR_str = struct.pack('I', tty.TIOCM_DTR)
self.TIOCM_RTS_str = struct.pack('I', tty.TIOCM_RTS)
self.state = initstate
self.switch(self.state)
def switch(self, state):
if state:
print "setting DTR"
fcntl.ioctl(self.fd, tty.TIOCMBIS, self.TIOCM_DTR_str)
print "setting RTS"
fcntl.ioctl(self.fd, tty.TIOCMBIS, self.TIOCM_RTS_str)
else:
print "clearing DTR"
fcntl.ioctl(self.fd, tty.TIOCMBIC, self.TIOCM_DTR_str)
print "clearing RTS"
fcntl.ioctl(self.fd, tty.TIOCMBIC, self.TIOCM_RTS_str)
self.state = state
def negate(self):
self.state = not self.state #negate
self.switch(self.state)
rele = Relay('/dev/ttyS0', initstate = False)
while True:
wait_period(3)
rele.negate()
runcommand('date')
Je to trochu lepší verze než ta předchozí. Jednak je to objektové a pak to časování je udělané tak, že se systematicky nepředbíhá ani nezpožďuje. Navíc se čas počítá absolutně, takže lze předem říct, že se kamery budou přepínat vždy v celou minutu a v půl.
Tiskni
Sdílej: