AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 772034
Accepted
Alex028502
Alex028502
Asked: 2024-03-11 03:25:11 +0800 CST2024-03-11 03:25:11 +0800 CST 2024-03-11 03:25:11 +0800 CST

o controle de trabalho não funciona quando tento configurar o getty via serial

  • 772

Estou tentando configurar o getty para fazer login via serial (principalmente como um experimento).

Com quase qualquer configuração, acontece a mesma coisa. Se meu shell padrão for bash, recebo esta mensagem após fazer login:

-bash: cannot set terminal process group (15297): Inappropriate ioctl for device
-bash: no job control in this shell

e então, para provar que não funciona, não posso usar ctrl+C para parar programas:

$ sleep 30
^C

e não parece enviar o sinal.

Estas são as configurações que tentei:

Eu tentei esses dois comandos

# copied from raspberry pi:
sudo /sbin/agetty --keep-baud 115200,38400,9600 ttyUSB0 vt220
# something else I read somewhere
sudo getty -L ttyUSB0 9600 vt100
# (I know I'm mixing and matching a lot of differences but the result is the same)

Eu tentei tanto o screen quanto o picocom como cliente.

Eu tentei usar um rasberry pi como servidor e dois laptops Ubuntu diferentes.

Eu tentei dois FTDIs, dois adaptadores USB RS-485 e um RS232 integrado no lado getty com um USB RS232 no lado do cliente.

Também tentei alterar meu shell padrão para sh e dash. Não recebo a mensagem, mas ctrl+C ainda não funciona como esperado

O engraçado é que quando o Raspberry Pi é configurado automaticamente /dev/ttyAMA0e usa exatamente o comando getty que eu coloquei, o controle do trabalho funciona!

E as configurações do terminal são quase idênticas. (exceto -iutf8 na verdade)

aqui estão as configurações do terminal com a conexão FTDI e picocom rodando:

$ stty -a -F /dev/ttyUSB0
speed 9600 baud; rows 24; columns 80; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D;
eol = <undef>; eol2 = <undef>; swtch = <undef>; start = ^Q;
stop = ^S; susp = ^Z; rprnt = ^R; werase = ^W;
lnext = <undef>; discard = <undef>; min = 1; time = 0;
-parenb -parodd -cmspar cs8 hupcl -cstopb cread clocal
-crtscts
-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr
-icrnl ixon ixoff -iuclc -ixany -imaxbel -iutf8
opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0
tab0 bs0 vt0 ff0
isig -icanon -iexten -echo echoe echok -echonl -noflsh -xcase
-tostop -echoprt echoctl echoke -flusho -extproc
$ stty -a -F /dev/ttyUSB1
speed 9600 baud; rows 0; columns 0; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D;
eol = <undef>; eol2 = <undef>; swtch = <undef>; start = ^Q;
stop = ^S; susp = ^Z; rprnt = ^R; werase = ^W; lnext = ^V;
discard = ^O; min = 1; time = 0;
-parenb -parodd -cmspar cs8 hupcl -cstopb cread clocal
-crtscts
-ignbrk -brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr
-icrnl -ixon -ixoff -iuclc -ixany -imaxbel -iutf8
-opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0
cr0 tab0 bs0 vt0 ff0
-isig -icanon -iexten -echo echoe echok -echonl -noflsh -xcase
-tostop -echoprt echoctl echoke -flusho -extproc

O que estou fazendo de errado? E por que funciona com a configuração integrada para a porta serial integrada no Raspberry Pi?

tty
  • 1 1 respostas
  • 21 Views

1 respostas

  • Voted
  1. Best Answer
    u1686_grawity
    2024-03-11T04:55:14+08:002024-03-11T04:55:14+08:00

    Não são os comandos, mas o ambiente em que eles são executados que faz a diferença.

    Normalmente getty é gerado diretamente do gerenciador de serviços do sistema (init) - tanto no systemd, onde é um .service, quanto no mundo SysV, onde possui uma entrada inittab (e não um script init.d!). Isso tem várias diferenças em relação a ser gerado em outro terminal.

    Principalmente, um processo iniciado a partir de um terminal o herda como seu terminal de controle, que é o parâmetro mais importante para o controle do shell job. Você pode ver isso em ps auxor ps -ef– os processos de serviço não têm ctty inicialmente, então quando getty abre o terminal indicado, ele se torna seu terminal de controle para controle de trabalho assim que o shell for executado. Mas um getty que foi iniciado a partir do seu xterm continuará a ter esse xterm pty como seu controlador tty, apesar de sua entrada/saída agora ser roteada para a porta serial.

    $ ps -C agetty
      PID TTY          TIME CMD
     1136 tty1     00:00:00 agetty
    14022 pts/22   00:00:00 agetty
          ^-- should be ttyS0!
    

    O terminal de controle define /dev/tty; define para quais processos os sinais de controle de trabalho são enviados; ele define quais processos são eliminados (SIGHUP'd) quando o terminal fecha. Se o seu shell herdou um tty de controle diferente do tty stdin/out, todos os tipos de coisas estranhas podem acontecer.

    Existem maneiras pelas quais um processo pode se desconectar de seu terminal anterior, como chamar setsid(), mas o getty não as utiliza automaticamente porque não espera ser executado dessa maneira. (Existe uma setsidferramenta que pode ser usada, mas você também não deveria usá-la aqui.)

    Idealmente, você deve apenas systemctl start serial-getty@ttyAMA0deixar o getty rodar em um ambiente limpo. Se forem necessárias opções personalizadas, edite esse serviço usando o 'systemctl edit' normal, mas nunca execute o getty diretamente. (Se o systemd não for usado, edite /etc/inittab; geralmente inclui um exemplo.)


    Existem muitas outras diferenças relativamente pequenas entre processos iniciados a partir de um shell e através de um gerenciador de serviços:

    • O processo herdará seu terminal como stdin/stdout/err. O Getty simplesmente os fechará e reabrirá para o que for necessário, mas muitos outros programas não o farão, e eu até vi serviços que mudam o comportamento com base nisso (... sem nenhuma boa razão, mas ainda assim).

    • O processo herdará diversas variáveis ​​de ambiente que podem ser relevantes ou inúteis. Por exemplo, porque você iniciou via sudo, ele terá SUDO_USER em seu ambiente (e algumas ferramentas realmente mudam seu comportamento quando veem que estão sendo chamadas via sudo).

    • O processo herdará seu contexto SELinux, se houver (por exemplo, no Fedora/RHEL), e poderá não ser permitido alterá-lo novamente. Ele também herda coisas como "uid de login" encontrado em /proc/PID/loginuid e não pode ser redefinido depois de definido (sendo usado para registro de auditoria). Em certas distribuições, também pode herdar perfis AppArmor, rótulos SMACK, etc.

    • O processo estará em seu cgroup de "usuário" original, mesmo que um usuário diferente efetue login. Systemd-logind adiciona um conceito de "sessões de usuário" ao Linux e as baseia em cgroups do Linux: quando um processo de serviço, como sshd ou agetty, processa seu login através do PAM, ele se registra no systemd-logind e é movido de seu cgroup de "serviço" para um cgroup de "usuário", como user-1002.slice. No entanto, um processo que já é executado dentro de um cgroup de "usuário" não tem permissão para fazer o mesmo novamente - mesmo que tenha privilégios de root.

    Tudo isso para dizer que existem muitas diferenças invisíveis e que no Linux você não deve iniciar serviços via sudo como prática geral; especialmente serviços que aceitam logins de usuários.

    • 2

relate perguntas

  • Usando o gpm como entrada do mouse em meu aplicativo iniciado em mc (comandante da meia-noite)

  • systemctl: Só funciona via tty2? (mesmo usuário logado em tty3&tty1.)

  • Executando um pseudoterminal dentro de um pseudoterminal

  • Comportamento do backspace no terminal

  • Por que o utilitário ssh é considerado um pty?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve