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 / 473824
Accepted
John P
John P
Asked: 2018-10-08 09:25:27 +0800 CST2018-10-08 09:25:27 +0800 CST 2018-10-08 09:25:27 +0800 CST

Quando saltamos para a parte do kernel da memória virtual do nosso processo, exceto quando usamos chamadas de sistema? (No Linux)

  • 772

Esta é uma pergunta de acompanhamento da minha pergunta anterior .

Com base na resposta, uma chamada de sistema é um exemplo de quando pulamos para a parte do kernel da memória virtual do nosso processo.

  1. Quais são outros exemplos de um processo normal (não kernel) usando essa parte da memória virtual além das chamadas do sistema? como existe alguma chamada de função que salta diretamente para esta parte do kernel ou ..?

  2. Quando pulamos para esta seção da memória, o processador define automaticamente o bit do modo kernel para 1 para que nosso processo acesse essa parte ou não há necessidade de definir esse bit?

  3. Toda a execução dentro desta parte do kernel acontece sem a necessidade de mudança de contexto para um processo do kernel?

(Eu não queria fazer essas perguntas de acompanhamento nos comentários, então abri outro tópico.)

insira a descrição da imagem aqui

linux kernel
  • 3 3 respostas
  • 1321 Views

3 respostas

  • Voted
  1. Best Answer
    Stephen Kitt
    2018-10-09T00:14:08+08:002018-10-09T00:14:08+08:00
    1. Os processos executados no modo de usuário não têm acesso ao espaço de endereço do kernel. Existem várias maneiras de o processador alternar para o modo kernel e executar o código do kernel, mas todas são configuradas pelo kernel e acontecem em contextos bem definidos: executar uma chamada de sistema, responder a uma interrupção ou lidar com uma falha. Chamadas de sistema não envolvem chamar diretamente o código do kernel; eles envolvem um mecanismo específico da arquitetura para solicitar à CPU que transfira o controle para o kernel, para executar uma chamada de sistema específica, identificada por seu número, em nome do processo de chamada. O LWN tem uma série de artigos explicando como isso funciona: Anatomia de uma chamada de sistema parte um , parte dois e conteúdo adicional .

      Se um processo tentar acessar a memória no espaço de endereço do kernel, ele mudará para o modo kernel, mas como resultado de uma falha; o kernel então matará o processo com uma violação de segmentação ( SIGSEGV).

      No x86 de 32 bits, existe um mecanismo para alternar para o modo kernel usando chamadas far, call gates ; mas o Linux não usa isso. (E eles contam com descritores de segmentos de código especiais em vez de chamar endereços do kernel.)

    2. Veja acima: você não pode pular para a memória do kernel. Nas circunstâncias descritas acima, ao fazer a transição para o modo kernel, a CPU verifica se a transição é permitida e, em caso afirmativo, alterna para o modo kernel usando qualquer mecanismo apropriado na arquitetura que está sendo usada. No Linux x86, isso significa alternar do anel 3 para o anel 0.

    3. A transição para o modo kernel não envolve uma mudança de processo, então sim, tudo isso acontece sem uma troca de contexto (conforme contado pelo kernel).

    • 5
  2. sourcejedi
    2018-10-08T14:42:49+08:002018-10-08T14:42:49+08:00

    1 e 2. Não, um programa de usuário não pode simplesmente usar uma instrução de salto para entrar na memória do kernel. Não é permitido fazê-lo. A CPU não define automaticamente o "bit do kernel" para permitir que esse salto seja bem-sucedido... (talvez alguma CPU tenha esse recurso, mas uma porta Linux segura desabilitaria esse recurso)

    ...Na verdade, já que você está acessando uma página de uma forma que não tem permissão para fazer, você entrará no kernel :-). Ele entra de forma controlada, funciona muito parecido com uma chamada de sistema, mas chamamos de "falta de página". A CPU fornecerá detalhes do acesso ao kernel. Com o tipo de acesso que você descreve, o kernel o tratará como um erro em seu programa :-). Ele enviará um sinal fatal para o seu programa (SIGSEGV).

    • 0
  3. Mark Smith
    2021-04-19T12:19:40+08:002021-04-19T12:19:40+08:00

    Tecnicamente, a memória do kernel pode ser mapeada em processos, ilegível, somente leitura ou leitura-gravação, e possivelmente até executada por processos saltando para o código armazenado nessa memória. Esta pode ser uma técnica para aumentar a velocidade de algumas syscalls onde é seguro executar código para manipular a syscall no processo e não no kernel. Ele também pode incluir dados como um endereço de memória contendo um valor de clock fornecido pelo kernel para que um processo não precise interromper para que o sistema possa entrar no kernel.

    Também é possível que os processos entrem em chamadas de sistema por interrupção no kernel através de INT 0x80, isso é o que muitos programadores de assembly estão familiarizados, mas certamente não é o único mecanismo que pode ser fornecido pelo kernel. Não existe uma regra rígida de que um kernel e os espaços de endereço do usuário tenham que ser completamente separados.

    Independentemente de qual abordagem o Linux usa, certamente é tecnicamente viável colocar código e dados do kernel em processos. O Linux também coloca a memória do kernel em processo rotineiramente, por motivos de desempenho relacionados a trocas de contexto e ao TLB, mas como muitas áreas do kernel são sensíveis, elas geralmente não são legíveis pelo processo.

    • -1

relate perguntas

  • astyle não altera a formatação do arquivo de origem

  • Como os desenvolvedores do kernel Linux lidam com seu trabalho com milhões de linhas de código? É um método? [fechado]

  • Passe o sistema de arquivos raiz por rótulo para o kernel do Linux

  • Acesse o sistema de arquivos como usuário root

Sidebar

Stats

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

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

    • 4 respostas
  • Marko Smith

    ssh Não é possível negociar: "nenhuma cifra correspondente encontrada", está rejeitando o cbc

    • 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

    Como descarregar o módulo do kernel 'nvidia-drm'?

    • 13 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
    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
    Wong Jia Hau ssh-add retorna com: "Erro ao conectar ao agente: nenhum arquivo ou diretório" 2018-08-24 23:28:13 +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
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +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