US20140201830A1 - Application program launching method and system for improving security of embedded linux kernel - Google Patents
Application program launching method and system for improving security of embedded linux kernel Download PDFInfo
- Publication number
- US20140201830A1 US20140201830A1 US14/218,706 US201414218706A US2014201830A1 US 20140201830 A1 US20140201830 A1 US 20140201830A1 US 201414218706 A US201414218706 A US 201414218706A US 2014201830 A1 US2014201830 A1 US 2014201830A1
- Authority
- US
- United States
- Prior art keywords
- application
- application program
- user identification
- user
- processor
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/30—Authentication, i.e. establishing the identity or authorisation of security principals
- G06F21/31—User authentication
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/52—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow
- G06F21/53—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow by executing in a restricted environment, e.g. sandbox or secure virtual machine
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
- G06F21/6227—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database where protection concerns the structure of data, e.g. records, types, queries
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2221/00—Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/21—Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/2141—Access rights, e.g. capability lists, access control lists, access tables, access matrices
Definitions
- the present invention relates generally to an application program launching method and system for improving security of an embedded Linux kernel, and in particular, to an application program launching method and system for improving security of an embedded Linux kernel by distributing superuser privileges.
- the embedded systems can be connected to external communication devices through fixed line and mobile networks.
- a general-purpose operating system such as Linux can be used in PDP and PMP devices, external programs created by users or program generators can be executed in the embedded systems. Therefore, the security of the embedded systems becomes very important.
- a general-purpose operating system such as Linux
- security methods are based on a multi-user environment, such as a conventional server-client environment.
- operating systems should separate user processors from system management processors in order to protect a system from users.
- the operating systems maintain a separate superuser account having most privileges required for managing the system.
- the superuser account is usually called root account.
- the root account has privileges for binding a particular port and a processor, loading a kernel module, mounting and unmounting filesystems, and various system managements.
- a representative example is a security kernel.
- the security kernel improves internal security of a kernel. That is, file access is allowed only to a user account of a user having a corresponding file, and network connection and communication between processors are allowed to a user account having corresponding privileges.
- the embedded systems are usually operated in single user environment instead of in a multi-user environment, such as a server-client environment, one user uses the embedded systems. Thus, in the embedded system, user accounts are not needed and most processors are executed with the root account.
- FIG. 1 is a block diagram illustrating an environment in which an application program is executed in an embedded system according to a conventional security method.
- each of processors of application programs 110 , 120 and 130 (hereinafter, referred to as an application program processor) is executed with the root account and can access a Linux kernel 100 without any limitation.
- the application program processors 110 , 120 and 130 can exercise all of the privileges accorded to the superuser (hereinafter, referred to as superuser privileges) even when they need part of superuser privileges, or do not need superuser privileges, they can access the imbedded system unnecessarily. Therefore, it is an inefficient way and a threat to the security of the embedded system to execute an application program in the embedded system according to the conventional security method based on the multi-user environment.
- an object of the present invention is to provide an application program launching method and system for enabling conventional security methods, which are used in a Linux operating system, to be used in an embedded system without modifying the conventional security methods to a large extent.
- a method for launching an application program on an embedded Linux kernel includes the steps of: searching security set information on an application program selected by a user; changing a user account for a processor of the application program to a user identification (ID) associated with the application program in the security set information; setting a capability for the processor according to setting information for the capability in the security set information; changing a basic directory for the processor according to a basic directory in the security set information; and launching the application program.
- the method may further include, before the step of searching the security set information, the step of installing the application program.
- the step of installing the application program may include the steps of: assigning a user ID to an application program to be installed; configuring setting information for a capability required by the application program; and storing a security set information including the user identification (ID) and the capability in a registry.
- a system for launching an application program on an imbedded Linux kernel includes: a user interface for receiving information on an application program selected by a user; a registry interface for searching security set information on the application program from a registry by communicating with a registry manager; and a controller for setting a user account, a capability, and a basic directory according to the security set information and launching a processor of the application program.
- the system may further include an application program installer for detecting the security set information on the application program to be installed and storing the detected security set information in the registry in the processor of installing the application program.
- a computer-readable recording medium storing a program for executing a method for launching an application program on an embedded Linux kernel, the method includes the steps of: searching security set information on an application program selected by a user; changing a user account for a processor of the application program to a user identification (ID) associated with the application program in the security set information; setting a capability for the processor according to setting information for the capability in the security set information; changing a basic directory for the processor according to a basic directory in the security set information; and launching the application program.
- ID user identification
- FIG. 1 is a block diagram illustrating an environment in which an application program is executed in an embedded system according to a conventional security method
- FIG. 2 is a flowchart illustrating a schematic procedure for launching an application program according to an embodiment of the present invention
- FIG. 3 is a diagram illustrating an environment in which an application launching processor is executed according to an embodiment of the present invention
- FIG. 4 is a block diagram of an application launching processor according to an embodiment of the present invention.
- FIG. 5 is a flowchart illustrating a procedure for launching an application program according to an embodiment of the present invention.
- FIG. 6 is a flowchart illustrating a procedure for installing an application program according to an embodiment of the present invention.
- FIGS. 2 through 6 discussed below, and the various embodiments used to describe the principles of the present disclosure in this patent document are by way of illustration only and should not be construed in any way to limit the scope of the disclosure. Those skilled in the art will understand that the principles of the present disclosure may be implemented in any suitably arranged processoring system.
- FIG. 2 is a flowchart illustrating a schematic procedure for launching an application program according to an embodiment of the present invention.
- a user 210 selects application programs to be launched.
- the application launching processor 220 enables the selected application program processors 232 , 234 and 236 to be launched on a Linux kernel 240 .
- the user 210 cannot launch the application program directly.
- the user 210 can launch the application program using only the application launching processor 220 .
- the application launching processor 220 serves as an interface between the user 210 and the application program processors 232 , 234 and 236 .
- the application launching processor 220 may be implemented as a daemon in an embedded Linux system because it should run continually while the embedded Linux system operates.
- the application launching processor 220 may be implemented in a graphical user interface (GUI), and in this case it also serves as a window manager managing the background screen and icons in the embedded Linux system. Accordingly, the application launching processor 220 may be implemented by modifying the window manager.
- GUI graphical user interface
- FIG. 3 is a diagram illustrating environment in which an application launching processor is executed according to an embodiment of the present invention.
- an application launching processor 320 requests a registry manager 330 for security set information on an application program in order to launch the application program and receives the security set information from the registry manager 330 .
- the registry manager 330 is a resident processor in order to manage information stored in a registry 332 .
- the registry manager 330 is implemented as a daemon called gconfd in a Linux operation system.
- the registry 332 is a database (DB) storing information on application programs. As illustrated in FIG. 3 , the registry 332 may store various information as well as security set information on application programs.
- DB database
- the security set information includes a user identification (ID) associated with an application program, a capability, and a basic directory.
- ID user identification
- a first field stores a user ID of ‘100’
- a second field stores a capability of ‘0x40f00000’
- a third field stores a basic directory of ‘/usr/local/class1’.
- the capability is the property of a processor based on which a Linux capability system adjusts the privileges of the processor.
- the Linux capability system assigns part of superuser privileges to a user processor. That is, a capability assigned to the user processor indicates privileges which the user processor exercises.
- a capability kernel module controls the operations of the user processor based on the capability assigned to the user processor.
- Table 1 is a list of capabilities as defined in the Linux kernel 2.2.13. They are taken from the kernel source in . . . include/linux/capability.h.
- CAP_SYS_NET_RAW 13 Allow use of raw sockets CAP_IPC_LOCK 14 Allow locking of memory segments CAP_IPC_OWNER 15 Override IPC ownership checks CAP_SYS_MODULE 16 Insert and remove kernel modules CAP_SYS_RAWIO 17 Allow access to ioperm and iopl CAP_SYS_CHROOT 18 Allow use of chroot( ) CAP_SYS_PTRACE 19 Allow tracing of any process CAP_SYS_PACCT 20 Allow configuration of process accounting CAP_SYS_ADMIN 21 Many sys admin tasks: mount, quotas, swapping, much more CAP_SYS_BOOT 22 Allow rebooting the system CAP_SYS_NICE 23 Allow raising priority, setting other process priority CAP_SYS_RESOURCE 24 Override resource limits CAP_SYS_TIME 25 Allow changing the system clock CAP_SYS_TTY_CONFIG 26 Allow configuration of tty devices
- a capability kernel module 312 determines if the first application program processor 342 is assigned with a superuser privilege for executing the operation, and controls the access to the Linux kernel 310 depending on the result of the determination.
- the application launching processor 320 may transmit identification information on an application program selected by a user to the registry manager 330 in order to request security set information on the application program.
- a user identification (ID) associated with the application program may be used as the identification information since different user IDs are assigned to application programs, respectively.
- the application launching processor 320 may map a user selection to a user ID using a mapping table. Description of the mapping table will be described below with reference to FIG. 4 .
- the registry manager 330 searches the security set information on the application program from the registry 332 and transmits the security set information to the application launching processor 320 .
- the application launching processor 320 launches the application program according to the security set information.
- Each application program that has a corresponding capability indicating execution privileges is executed with a corresponding user ID and on a corresponding basic directory.
- the basic directory is a root directory of a file system, which a corresponding application program processor recognizes. Different basic directories are assigned to the first application program processor 342 and the second application program processor 344 , respectively. One basic directory is assigned to the third application program processor 346 and the fourth application program processor 348 .
- FIG. 4 is a block diagram of an application launching precessor according to an embodiment of the present invention.
- An application launching processor 400 executing an application launching processor includes a controller 402 , a user interface 404 , a registry interface 406 , and a mapping table 408 .
- the user interface 404 receives information on an application program selected by a user 410 .
- the registry interface 406 requests from a registry manager 430 security set information on the application program.
- the registry interface 406 also transmits identification (ID) information on the application program to the registry manager 430 .
- ID identification
- a user ID associated with the application program may be used as the identification information.
- the mapping table 408 searches the user ID using, for example, an icon selected by the user 410 .
- the registry interface 406 receives the security set information from the registry manager 430 and sets a user account, a capability, and a basic directory based on the received security set information to launch the application program.
- FIG. 5 is a flowchart illustrating a procedure for launching an application program according to an embodiment of the present invention.
- step 501 an application program is installed.
- the installation of the application program will be described with reference to FIG. 6 .
- FIG. 6 is a flowchart illustrating a procedure for installing an application program according to an embodiment of the present invention.
- the installation procedure may be performed by a separate installation processor.
- a user ID is assigned to an application program to be installed.
- the assigned user ID is different from existing user IDs assigned to preinstalled application programs.
- different user IDs may be assigned to application programs, respectively.
- Each application program is executed in a manner in which application programs are executed by corresponding users, respectively.
- each application program processor can be executed independently, as in a multi-user environment.
- different user accounts are assigned to application program processors, respectively, so that the above described secure method according to the present invention is designed based on a user ID assigned to an application program.
- step 602 setting information for a capability assigned to the application program processor is configured.
- the installation processor determines which superuser privileges are required to execute the application program and configures the setting information in order to set the capability corresponding to the required privileges.
- an application launching processor may set the capability for the application program processor using the configured setting information.
- the installation processor assigns a basic directory to the application program processor.
- different basic directories can be assigned to application program processors, respectively, or one basic directory can be assigned to a plurality of application program processors.
- the installation processor assigns a share basic directory or a separate basic directory depending on the characteristics of the application program.
- each application program processor has part of superuser privileges, but cannot access files related to the operations of the embedded system, so that the embedded system can be protected from an attack application program and damage due to external attacks can be limited to attacked application programs.
- a basic directory is isolated from other application program processors that belong to other directories, so that it can be prevented that undesired files are modified and changed. Accordingly, security between application program processors can be improved and damage due to viruses can be minimized.
- step 604 the security set information including the user ID, the capability, and the basic directory is stored in a registry.
- the security set information stored in the registry will be used in the processor of launching the installed application program.
- a user selects an application program to be launched.
- the selection of the application program may be made through a user interface implemented in a GUI.
- a registry interface searches security set information on the selected application program from the registry through a registry manager.
- the security set information includes a user ID associated with the selected application program, a capability, and a basic directory.
- a controller changes a user account for an application program processor to the user ID in the security set information.
- the controller may change the user account for the application program processor using a setuid( ) command of a Linux system.
- the application launching processor determines whether the application program processor is a system management processor.
- a system management processor is a processor that needs part of the superuser privileges. The determination may be made based on the setting information for the capability in the security set information. If the application program processor is not a system management processor, since the application program processor does not need part of the superuser privileges, the step 506 of setting the capability can be omitted.
- all application program processors are created as child processors of the application launching processor using a fork( ) command, and a Linux kernel creates new processors based on a default capability. Thus, when the application program processor is not the system management processor, the application program processor can be launched without the processor of setting the capability.
- the controller in step 506 , sets the capability based on the setting information for the capability in the security set information.
- step 507 the controller changes a basic directory of the application program processor according to the basic directory in the security set information.
- step 508 the controller launches the application program.
- the controller may use a chroot( ) command of the Linux system.
- the above described application program launching method for improving the security of the embedded Linux kernel can be implemented by a computer-readable recording medium of a computer-readable code.
- the computer-readable recording medium is a recording medium for storing data that can be read by computer systems.
- the computer-readable recording medium includes a ROM, a RAM, a CD-ROM, a magnetic tape, a floppy disk, and an optical data storage device.
- a carrier wave e.g., transmission through Internet
- the computer-readable recording medium can be distributed among computer systems that are interconnected through a network and stored in computer-readable codes.
- the application program processor is executed in the manner in which each application program processor is executed by a respective user, so that the embedded Linux system can be configured using conventional Linux system security functions.
- the role of a superuser in the Linux system is minimized and the processor of an application program is executed independently, thereby minimizing damage due to external attacks.
- the present invention provides the security method optimized for the embedded system based on the Linux operating system, so that the security of the embedded system is improved and a general-purpose operating system such as the Linux operating system is easily applied to the embedded systems.
- the present invention improves security of the embedded system in a cost effective manner by providing the method for applying security method based on the multi-user environment used in the general-purpose operating system to the embedded system without modifying the security method to a large extent.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Health & Medical Sciences (AREA)
- Bioethics (AREA)
- Health & Medical Sciences (AREA)
- Databases & Information Systems (AREA)
- Stored Programmes (AREA)
- Storage Device Security (AREA)
Abstract
Provided is an application program launching method and system for improving security of an embedded Linux kernel by distributing superuser privileges. The method includes: searching security set information on an application program selected by a user; changing a user account for a processor of the application program to a user ID associated with the application program in the security set information; setting a capability for the processor according to setting information for the capability in the security set information; changing a basic directory for the processor according to a basic directory in the security set information; and launching the application program.
Description
- This application claims priority under 35 U.S.C. §119(a) to an application filed in the Korean Intellectual Property Office on Dec. 5, 2006 and allocated Serial No. 2006-0122245, and an application filed in the Korean Intellectual Property Office on Oct. 4, 2007 and allocated Serial No. 2007-0100071 the contents of which are incorporated herein by reference.
- The present invention relates generally to an application program launching method and system for improving security of an embedded Linux kernel, and in particular, to an application program launching method and system for improving security of an embedded Linux kernel by distributing superuser privileges.
- As hardware processor technologies are developing, the performance of embedded systems is dramatically improved. Thus, the embedded systems can be connected to external communication devices through fixed line and mobile networks. As a general-purpose operating system such as Linux can be used in PDP and PMP devices, external programs created by users or program generators can be executed in the embedded systems. Therefore, the security of the embedded systems becomes very important.
- In a general-purpose operating system such as Linux, security methods are based on a multi-user environment, such as a conventional server-client environment. In a multi-user environment, operating systems should separate user processors from system management processors in order to protect a system from users. For this purpose, the operating systems maintain a separate superuser account having most privileges required for managing the system. In a Unix type operating systems such as Linux, the superuser account is usually called root account. The root account has privileges for binding a particular port and a processor, loading a kernel module, mounting and unmounting filesystems, and various system managements.
- Therefore, in conventional Linux operating systems, security methods are designed based on a user account instead of the root account. A representative example is a security kernel. The security kernel improves internal security of a kernel. That is, file access is allowed only to a user account of a user having a corresponding file, and network connection and communication between processors are allowed to a user account having corresponding privileges.
- Since the embedded systems are usually operated in single user environment instead of in a multi-user environment, such as a server-client environment, one user uses the embedded systems. Thus, in the embedded system, user accounts are not needed and most processors are executed with the root account.
-
FIG. 1 is a block diagram illustrating an environment in which an application program is executed in an embedded system according to a conventional security method. Referring toFIG. 1 , each of processors ofapplication programs kernel 100 without any limitation. Because theapplication program processors - To address the above-discussed deficiencies of the prior art, it is a primary object of the present invention to substantially solve at least the above problems and/or disadvantages and to provide at least the advantages below. Accordingly, an object of the present invention is to provide an application program launching method and system for enabling conventional security methods, which are used in a Linux operating system, to be used in an embedded system without modifying the conventional security methods to a large extent.
- According to one aspect of the present invention, a method for launching an application program on an embedded Linux kernel includes the steps of: searching security set information on an application program selected by a user; changing a user account for a processor of the application program to a user identification (ID) associated with the application program in the security set information; setting a capability for the processor according to setting information for the capability in the security set information; changing a basic directory for the processor according to a basic directory in the security set information; and launching the application program. The method may further include, before the step of searching the security set information, the step of installing the application program. The step of installing the application program may include the steps of: assigning a user ID to an application program to be installed; configuring setting information for a capability required by the application program; and storing a security set information including the user identification (ID) and the capability in a registry.
- According to another aspect of the present invention, a system for launching an application program on an imbedded Linux kernel includes: a user interface for receiving information on an application program selected by a user; a registry interface for searching security set information on the application program from a registry by communicating with a registry manager; and a controller for setting a user account, a capability, and a basic directory according to the security set information and launching a processor of the application program. The system may further include an application program installer for detecting the security set information on the application program to be installed and storing the detected security set information in the registry in the processor of installing the application program.
- According to still another aspect of the present invention, a computer-readable recording medium storing a program for executing a method for launching an application program on an embedded Linux kernel, the method includes the steps of: searching security set information on an application program selected by a user; changing a user account for a processor of the application program to a user identification (ID) associated with the application program in the security set information; setting a capability for the processor according to setting information for the capability in the security set information; changing a basic directory for the processor according to a basic directory in the security set information; and launching the application program.
- Before undertaking the DETAILED DESCRIPTION OF THE INVENTION below, it may be advantageous to set forth definitions of certain words and phrases used throughout this patent document: the terms “include” and “comprise,” as well as derivatives thereof, mean inclusion without limitation; the term “or,” is inclusive, meaning and/or; the phrases “associated with” and “associated therewith,” as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, or the like; and the term “controller” means any device, system or part thereof that controls at least one operation, such a device may be implemented in hardware, firmware or software, or some combination of at least two of the same. It should be noted that the functionality associated with any particular controller may be centralized or distributed, whether locally or remotely. Definitions for certain words and phrases are provided throughout this patent document, those of ordinary skill in the art should understand that in many, if not most instances, such definitions apply to prior, as well as future uses of such defined words and phrases.
- For a more complete understanding of the present disclosure and its advantages, reference is now made to the following description taken in conjunction with the accompanying drawings, in which like reference numerals represent like parts:
-
FIG. 1 is a block diagram illustrating an environment in which an application program is executed in an embedded system according to a conventional security method; -
FIG. 2 is a flowchart illustrating a schematic procedure for launching an application program according to an embodiment of the present invention; -
FIG. 3 is a diagram illustrating an environment in which an application launching processor is executed according to an embodiment of the present invention; -
FIG. 4 is a block diagram of an application launching processor according to an embodiment of the present invention; -
FIG. 5 is a flowchart illustrating a procedure for launching an application program according to an embodiment of the present invention; and -
FIG. 6 is a flowchart illustrating a procedure for installing an application program according to an embodiment of the present invention. -
FIGS. 2 through 6 , discussed below, and the various embodiments used to describe the principles of the present disclosure in this patent document are by way of illustration only and should not be construed in any way to limit the scope of the disclosure. Those skilled in the art will understand that the principles of the present disclosure may be implemented in any suitably arranged processoring system. -
FIG. 2 is a flowchart illustrating a schematic procedure for launching an application program according to an embodiment of the present invention. - Referring to
FIG. 2 , using anapplication launching processor 220, auser 210 selects application programs to be launched. Theapplication launching processor 220 enables the selectedapplication program processors kernel 240. - Thus, the
user 210 cannot launch the application program directly. Theuser 210 can launch the application program using only theapplication launching processor 220. In other words, theapplication launching processor 220 serves as an interface between theuser 210 and theapplication program processors application launching processor 220 may be implemented as a daemon in an embedded Linux system because it should run continually while the embedded Linux system operates. Generally, theapplication launching processor 220 may be implemented in a graphical user interface (GUI), and in this case it also serves as a window manager managing the background screen and icons in the embedded Linux system. Accordingly, theapplication launching processor 220 may be implemented by modifying the window manager. -
FIG. 3 is a diagram illustrating environment in which an application launching processor is executed according to an embodiment of the present invention. - Referring to
FIG. 3 , anapplication launching processor 320 requests aregistry manager 330 for security set information on an application program in order to launch the application program and receives the security set information from theregistry manager 330. Theregistry manager 330 is a resident processor in order to manage information stored in aregistry 332. Generally, theregistry manager 330 is implemented as a daemon called gconfd in a Linux operation system. - The
registry 332 is a database (DB) storing information on application programs. As illustrated inFIG. 3 , theregistry 332 may store various information as well as security set information on application programs. - The security set information includes a user identification (ID) associated with an application program, a capability, and a basic directory. For example, in a first application stored in the
registry 332 inFIG. 3 , a first field stores a user ID of ‘100’, a second field stores a capability of ‘0x40f00000’, and a third field stores a basic directory of ‘/usr/local/class1’. - The capability is the property of a processor based on which a Linux capability system adjusts the privileges of the processor. The Linux capability system assigns part of superuser privileges to a user processor. That is, a capability assigned to the user processor indicates privileges which the user processor exercises. A capability kernel module controls the operations of the user processor based on the capability assigned to the user processor. The following Table 1 is a list of capabilities as defined in the Linux kernel 2.2.13. They are taken from the kernel source in . . . include/linux/capability.h.
-
TABLE 1 NAME NUMBER DESCRIPTION CAP_CHOWN 0 Override restrictions on changing file ownership CAP_DAC_OVERRIDE 1 Override access restriction on files CAP_DAC_READ_SEARCH 2 Override restrictions on read and search of files and directories CAP_FOWNER 3 Override restrictions on files when owned by processes CAP_FSETID 4 Allow setting setuid bits (not implemented) CAP_KILL 5 Allow sending signals to processes owned by others CAP_SETGID 6 Allow group ID manipulation CAP_SETUID 7 Allow user id manipulation CAP_SETPGAP 8 Transfer capabilities to other processes CAP_LINUX_IMMUTABLE 9 Allow modification of immutable and append-only file attributes CAP_NET_BIND_SERVICE 10 Allow binding to sockets below 1024 CAP_NET_BROADCAST 11 Allow network broadcasting and multicast access CAP_NET_ADMIN 12 Allow net admin tasks - interfaces, firewalls, routing, . . . CAP_NET_RAW 13 Allow use of raw sockets CAP_IPC_LOCK 14 Allow locking of memory segments CAP_IPC_OWNER 15 Override IPC ownership checks CAP_SYS_MODULE 16 Insert and remove kernel modules CAP_SYS_RAWIO 17 Allow access to ioperm and iopl CAP_SYS_CHROOT 18 Allow use of chroot( ) CAP_SYS_PTRACE 19 Allow tracing of any process CAP_SYS_PACCT 20 Allow configuration of process accounting CAP_SYS_ADMIN 21 Many sys admin tasks: mount, quotas, swapping, much more CAP_SYS_BOOT 22 Allow rebooting the system CAP_SYS_NICE 23 Allow raising priority, setting other process priority CAP_SYS_RESOURCE 24 Override resource limits CAP_SYS_TIME 25 Allow changing the system clock CAP_SYS_TTY_CONFIG 26 Allow configuration of tty devices - For example, when a first
application program processor 342 attempts to gain access to aLinux kernel 310 in order to execute an operation restricted under the superuser privileges, acapability kernel module 312 determines if the firstapplication program processor 342 is assigned with a superuser privilege for executing the operation, and controls the access to theLinux kernel 310 depending on the result of the determination. - The
application launching processor 320 may transmit identification information on an application program selected by a user to theregistry manager 330 in order to request security set information on the application program. In one embodiment, a user identification (ID) associated with the application program may be used as the identification information since different user IDs are assigned to application programs, respectively. Theapplication launching processor 320 may map a user selection to a user ID using a mapping table. Description of the mapping table will be described below with reference toFIG. 4 . - In response to the request of the
application launching processor 320, theregistry manager 330 searches the security set information on the application program from theregistry 332 and transmits the security set information to theapplication launching processor 320. Theapplication launching processor 320 launches the application program according to the security set information. Each application program that has a corresponding capability indicating execution privileges is executed with a corresponding user ID and on a corresponding basic directory. - The basic directory is a root directory of a file system, which a corresponding application program processor recognizes. Different basic directories are assigned to the first
application program processor 342 and the secondapplication program processor 344, respectively. One basic directory is assigned to the thirdapplication program processor 346 and the fourthapplication program processor 348. -
FIG. 4 is a block diagram of an application launching precessor according to an embodiment of the present invention. - An
application launching processor 400 executing an application launching processor includes acontroller 402, auser interface 404, a registry interface 406, and a mapping table 408. Theuser interface 404 receives information on an application program selected by auser 410. Based on the received information, the registry interface 406 requests from aregistry manager 430 security set information on the application program. In the request, the registry interface 406 also transmits identification (ID) information on the application program to theregistry manager 430. In one embodiment, a user ID associated with the application program may be used as the identification information. The mapping table 408 searches the user ID using, for example, an icon selected by theuser 410. - The registry interface 406 receives the security set information from the
registry manager 430 and sets a user account, a capability, and a basic directory based on the received security set information to launch the application program. -
FIG. 5 is a flowchart illustrating a procedure for launching an application program according to an embodiment of the present invention. - In
step 501, an application program is installed. The installation of the application program will be described with reference toFIG. 6 . -
FIG. 6 is a flowchart illustrating a procedure for installing an application program according to an embodiment of the present invention. The installation procedure may be performed by a separate installation processor. Referring toFIG. 6 , in step 601, a user ID is assigned to an application program to be installed. The assigned user ID is different from existing user IDs assigned to preinstalled application programs. In embedded systems, since the number of application programs to be launched is relatively small, different user IDs may be assigned to application programs, respectively. Each application program is executed in a manner in which application programs are executed by corresponding users, respectively. Also each application program processor can be executed independently, as in a multi-user environment. Moreover, different user accounts are assigned to application program processors, respectively, so that the above described secure method according to the present invention is designed based on a user ID assigned to an application program. - In step 602, setting information for a capability assigned to the application program processor is configured. The installation processor determines which superuser privileges are required to execute the application program and configures the setting information in order to set the capability corresponding to the required privileges. In the processor of launching the application program, an application launching processor may set the capability for the application program processor using the configured setting information.
- In
step 603, the installation processor assigns a basic directory to the application program processor. As described above, different basic directories can be assigned to application program processors, respectively, or one basic directory can be assigned to a plurality of application program processors. Thus, the installation processor assigns a share basic directory or a separate basic directory depending on the characteristics of the application program. As a result, each application program processor has part of superuser privileges, but cannot access files related to the operations of the embedded system, so that the embedded system can be protected from an attack application program and damage due to external attacks can be limited to attacked application programs. In addition, a basic directory is isolated from other application program processors that belong to other directories, so that it can be prevented that undesired files are modified and changed. Accordingly, security between application program processors can be improved and damage due to viruses can be minimized. - In
step 604, the security set information including the user ID, the capability, and the basic directory is stored in a registry. The security set information stored in the registry will be used in the processor of launching the installed application program. - Again referring to
FIG. 5 , instep 502, a user selects an application program to be launched. In one embodiment, the selection of the application program may be made through a user interface implemented in a GUI. - In
step 503, a registry interface searches security set information on the selected application program from the registry through a registry manager. The security set information includes a user ID associated with the selected application program, a capability, and a basic directory.Instep 504, a controller changes a user account for an application program processor to the user ID in the security set information. In one embodiment, the controller may change the user account for the application program processor using a setuid( ) command of a Linux system. - In step 505, the application launching processor determines whether the application program processor is a system management processor. A system management processor is a processor that needs part of the superuser privileges. The determination may be made based on the setting information for the capability in the security set information. If the application program processor is not a system management processor, since the application program processor does not need part of the superuser privileges, the
step 506 of setting the capability can be omitted. According to the present invention, all application program processors are created as child processors of the application launching processor using a fork( ) command, and a Linux kernel creates new processors based on a default capability. Thus, when the application program processor is not the system management processor, the application program processor can be launched without the processor of setting the capability. - If the application program processor is a system management processor, since the application program processor needs part of the superuser privileges, the controller, in
step 506, sets the capability based on the setting information for the capability in the security set information. - In
step 507, the controller changes a basic directory of the application program processor according to the basic directory in the security set information. Instep 508, the controller launches the application program. In the processor of changing the basic directory, the controller may use a chroot( ) command of the Linux system. - The above described application program launching method for improving the security of the embedded Linux kernel can be implemented by a computer-readable recording medium of a computer-readable code. The computer-readable recording medium is a recording medium for storing data that can be read by computer systems. The computer-readable recording medium includes a ROM, a RAM, a CD-ROM, a magnetic tape, a floppy disk, and an optical data storage device. In addition, a carrier wave (e.g., transmission through Internet) is the computer-readable recording medium. Moreover, the computer-readable recording medium can be distributed among computer systems that are interconnected through a network and stored in computer-readable codes.
- According to the present invention applied to the embedded systems used by one user, the application program processor is executed in the manner in which each application program processor is executed by a respective user, so that the embedded Linux system can be configured using conventional Linux system security functions.
- In the present invention, the role of a superuser in the Linux system is minimized and the processor of an application program is executed independently, thereby minimizing damage due to external attacks.
- The present invention provides the security method optimized for the embedded system based on the Linux operating system, so that the security of the embedded system is improved and a general-purpose operating system such as the Linux operating system is easily applied to the embedded systems.
- The present invention improves security of the embedded system in a cost effective manner by providing the method for applying security method based on the multi-user environment used in the general-purpose operating system to the embedded system without modifying the security method to a large extent.
- Although the present disclosure has been described with an exemplary embodiment, various changes and modifications may be suggested to one skilled in the art. It is intended that the present disclosure encompass such changes and modifications as fall within the scope of the appended claims.
Claims (22)
1-17. (canceled)
18. A method comprising:
obtaining, at an electronic device, a process corresponding to an application in response to a request for the application;
identifying at least one portion of a first user identification assigned to the application; and
assigning a second user identification to the process based at least in part on the at least one portion.
19. The method of claim 18 , further comprising:
assigning the first user identification to the application during installation of the application to the electronic device.
20. The method of claim 19 , wherein the assigning of the first user identification comprises:
assigning at least one of a permission or a directory to the application.
21. The method of claim 18 , wherein the identifying comprises:
searching the first user identification from a plurality of user identifications stored at the electronic device, each of the plurality of user identifications assigned to a different application.
22. The method of claim 18 , wherein the identifying comprises:
identifying at least one of a permission or a directory assigned to the application.
23. The method of claim 18 , wherein the assigning of the second user identification comprises:
determining a first permission assigned to the application; and
assigning a second permission to the process based at least in part on the first permission.
24. The method of claim 23 , further comprising:
accessing at least one resource using the process based at least in part on the second permission.
25. The method of claim 18 , further comprising:
executing the application using the process, the executing including accessing at least one resource based at least in part on the second user identification.
26. The method of claim 18 , further comprising:
assigning a third user identification to another process corresponding to another application based at least in part on a fourth user identification assigned to the other application.
27. The method of claim 26 , further comprising:
executing the other application using the other process, the executing including accessing at least one resource based at least in part on the third user identification.
28. An apparatus comprising:
a memory configured to store at least one user identification corresponding to at least one application; and
a controller operatively coupled to the memory, the controller configured to:
obtain a process corresponding to an application in response to a request for the application;
identify at least one portion of a first user identification assigned to the application; and
assign a second user identification to the process based at least in part on the at least one portion.
29. The apparatus of claim 28 , wherein the controller is configured to assign the first user identification to the application during installation of the application to the electronic device.
30. The apparatus of claim 28 , wherein the controller is configured to assign at least one of a permission or a directory to the application during installation of the application to the electronic device.
31. The apparatus of claim 28 , wherein the controller is configured to search the first user identification from a plurality of user identifications stored at the apparatus, each of the plurality of user identifications assigned to a different application.
32. The apparatus of claim 28 , wherein the controller is configured to identify at least one of a permission or a directory assigned to the application.
33. The apparatus of claim 28 , wherein the controller is configured to:
determine a first permission assigned to the application; and
assign a second permission to the process based at least in part on the first permission.
34. The apparatus of claim 33 , wherein the controller is configured to access at least one resource using the process based at least in part on the second permission.
35. The apparatus of claim 28 , wherein the controller is configured to execute the application using the process, the executing including accessing at least one resource based at least in part on the second user identification.
36. The apparatus of claim 28 , wherein the controller is configured to assign a third user identification to another process corresponding to another application based at least in part on a fourth user identification assigned to the other application.
37. The apparatus of claim 36 , wherein the controller is configured to execute the other application using the other process, the executing including accessing at least one resource based at least in part on the third user identification.
38. A non-transitory machine-readable storage device storing instructions that, when executed by one or more processors, cause the one or more processors to perform operations comprising:
obtaining, at an electronic device, a process corresponding to an application in response to a request for the application;
identifying at least one portion of a first user identification assigned to the application; and
assigning a second user identification to the process based at least in part on the at least one portion.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/218,706 US20140201830A1 (en) | 2006-12-05 | 2014-03-18 | Application program launching method and system for improving security of embedded linux kernel |
Applications Claiming Priority (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR20060122245 | 2006-12-05 | ||
KR2007-0100071 | 2007-10-04 | ||
KR1020070100071A KR100915803B1 (en) | 2006-12-05 | 2007-10-04 | Application Program Launching Method and System for Improving Security of Embedded Linux Kernel |
US11/999,217 US8677477B2 (en) | 2006-12-05 | 2007-12-04 | Application program launching method and system for improving security of embedded Linux kernel |
KR2006-0122245 | 2007-12-05 | ||
US14/218,706 US20140201830A1 (en) | 2006-12-05 | 2014-03-18 | Application program launching method and system for improving security of embedded linux kernel |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/999,217 Continuation US8677477B2 (en) | 2006-12-05 | 2007-12-04 | Application program launching method and system for improving security of embedded Linux kernel |
Publications (1)
Publication Number | Publication Date |
---|---|
US20140201830A1 true US20140201830A1 (en) | 2014-07-17 |
Family
ID=39807173
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/999,217 Expired - Fee Related US8677477B2 (en) | 2006-12-05 | 2007-12-04 | Application program launching method and system for improving security of embedded Linux kernel |
US14/218,706 Abandoned US20140201830A1 (en) | 2006-12-05 | 2014-03-18 | Application program launching method and system for improving security of embedded linux kernel |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/999,217 Expired - Fee Related US8677477B2 (en) | 2006-12-05 | 2007-12-04 | Application program launching method and system for improving security of embedded Linux kernel |
Country Status (4)
Country | Link |
---|---|
US (2) | US8677477B2 (en) |
EP (1) | EP2045747B1 (en) |
KR (1) | KR100915803B1 (en) |
CN (1) | CN101403973B (en) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10205714B2 (en) | 2015-08-04 | 2019-02-12 | Electronics And Telecommunications Research Institute | Apparatus and method for process authentication in redundant system |
US10325116B2 (en) * | 2017-06-30 | 2019-06-18 | Vmware, Inc. | Dynamic privilege management in a computer system |
CN111639020A (en) * | 2020-05-06 | 2020-09-08 | 贝壳技术有限公司 | Program bug reproduction method, system, device, electronic equipment and storage medium thereof |
US11675902B2 (en) | 2018-12-05 | 2023-06-13 | Vmware, Inc. | Security detection system with privilege management |
Families Citing this family (27)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100915803B1 (en) * | 2006-12-05 | 2009-09-07 | 한국전자통신연구원 | Application Program Launching Method and System for Improving Security of Embedded Linux Kernel |
US20100157990A1 (en) * | 2008-12-19 | 2010-06-24 | Openpeak, Inc. | Systems for providing telephony and digital media services |
US20120102564A1 (en) * | 2010-10-25 | 2012-04-26 | Openpeak Inc. | Creating distinct user spaces through mountable file systems |
US8650658B2 (en) | 2010-10-25 | 2014-02-11 | Openpeak Inc. | Creating distinct user spaces through user identifiers |
US20120227035A1 (en) * | 2011-03-03 | 2012-09-06 | Microsoft Corporation | Cross platform service notification |
US9015790B2 (en) * | 2011-07-20 | 2015-04-21 | Red Hat, Inc. | Integrating sudo rules with entities represented in an LDAP directory |
US8695060B2 (en) | 2011-10-10 | 2014-04-08 | Openpeak Inc. | System and method for creating secure applications |
CN102591727B (en) * | 2012-01-04 | 2014-09-17 | 华为终端有限公司 | Method for processing application data and computing node |
KR101195292B1 (en) | 2012-03-08 | 2012-10-26 | 윤종선 | Apparatus and method for managing identity |
CN103377042B (en) * | 2012-04-24 | 2016-04-13 | 深圳市腾讯计算机系统有限公司 | Power of carrying method and system under the class Unix environment of windows system |
CN103514003B (en) * | 2012-06-28 | 2018-02-13 | 腾讯科技(深圳)有限公司 | Program installation method and device |
US9058189B1 (en) * | 2012-08-08 | 2015-06-16 | Google Inc. | Automatic user account selection for launching an application |
CN104091132B (en) * | 2014-06-17 | 2017-07-28 | 小米科技有限责任公司 | Method, device and the routing device of plug-in unit are run on routing device |
US11275861B2 (en) * | 2014-07-25 | 2022-03-15 | Fisher-Rosemount Systems, Inc. | Process control software security architecture based on least privileges |
US20160071040A1 (en) | 2014-09-05 | 2016-03-10 | Openpeak Inc. | Method and system for enabling data usage accounting through a relay |
US9100390B1 (en) | 2014-09-05 | 2015-08-04 | Openpeak Inc. | Method and system for enrolling and authenticating computing devices for data usage accounting |
US8938547B1 (en) | 2014-09-05 | 2015-01-20 | Openpeak Inc. | Method and system for data usage accounting in a computing device |
US9232013B1 (en) | 2014-09-05 | 2016-01-05 | Openpeak Inc. | Method and system for enabling data usage accounting |
US9350818B2 (en) | 2014-09-05 | 2016-05-24 | Openpeak Inc. | Method and system for enabling data usage accounting for unreliable transport communication |
CN104484594B (en) * | 2014-11-06 | 2017-10-31 | 中国科学院信息工程研究所 | A kind of franchise distribution method of the Linux system based on capability mechanism |
CN104462980A (en) * | 2014-12-30 | 2015-03-25 | 北京奇虎科技有限公司 | Authority management method, device and system of application programs and mobile terminal |
CN105138898A (en) * | 2015-07-22 | 2015-12-09 | 北京元心科技有限公司 | Method for allocating operation right to application program in intelligent terminal |
CN105653960A (en) * | 2015-12-31 | 2016-06-08 | 北京元心科技有限公司 | Linux capability distribution method and device |
CN108595944B (en) * | 2018-03-27 | 2020-07-10 | 麒麟软件有限公司 | Method for realizing UID uniqueness of user based on L inux system |
KR102222868B1 (en) * | 2019-05-02 | 2021-03-04 | (주)휴네시온 | Linux-based security systems and methods for usb serial devices |
CN113760374B (en) * | 2021-08-30 | 2023-04-21 | 海信电子科技(深圳)有限公司 | Binding method and device of processor and electronic equipment |
CN118426858A (en) * | 2024-04-12 | 2024-08-02 | 珠海瑞捷电气股份有限公司 | Shell-based embedded Linux system application program starting method and system |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5113442A (en) * | 1989-03-06 | 1992-05-12 | Lachman Associates, Inc. | Method and apparatus for providing access control in a secure operating system |
US6289462B1 (en) * | 1998-09-28 | 2001-09-11 | Argus Systems Group, Inc. | Trusted compartmentalized computer operating system |
US20050091658A1 (en) * | 2003-10-24 | 2005-04-28 | Microsoft Corporation | Operating system resource protection |
US20050289545A1 (en) * | 2004-06-24 | 2005-12-29 | Blinick Stephen L | Method to enable user mode process to operate in a privileged execution mode |
US20060020063A1 (en) * | 2004-07-22 | 2006-01-26 | Guenther Gerhard K | Controlled finishes for free surface polyethylene resins |
US20060053426A1 (en) * | 2002-05-28 | 2006-03-09 | Symbian Limited | Secure mobile wireless device |
US20060253909A1 (en) * | 2005-05-06 | 2006-11-09 | Mikhail Cherepov | Method to control and secure setuid/gid executables and processes |
US20070050369A1 (en) * | 2005-01-31 | 2007-03-01 | Stiegler Marc D | Accessing file under confinement |
US7383437B1 (en) * | 2003-09-08 | 2008-06-03 | Sun Microsystems, Inc. | Method and system for implementing super-user-compatible privileges |
US8677477B2 (en) * | 2006-12-05 | 2014-03-18 | Samsung Electronics Co., Ltd. | Application program launching method and system for improving security of embedded Linux kernel |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US188649A (en) * | 1877-03-20 | Improvement in lamps | ||
US53426A (en) * | 1866-03-27 | Improvement in telegraph-insulators | ||
US50369A (en) * | 1865-10-10 | Improvement in knitting-machwes | ||
KR20020033859A (en) * | 2000-10-30 | 2002-05-08 | 송영호 | Linux security kernel |
KR100351953B1 (en) * | 2000-11-24 | 2002-09-12 | 엘지전자 주식회사 | System and Method of Protecting Process |
KR100396308B1 (en) * | 2001-03-26 | 2003-09-03 | 주식회사데이콤 | Linux System and Operating Method of the Linux System having improved access control function |
US20020188649A1 (en) | 2001-06-12 | 2002-12-12 | Ron Karim | Mechanism for safely executing an untrusted program |
US7065783B2 (en) * | 2001-07-06 | 2006-06-20 | Aramira Corporation | Mobile application access control list security system |
KR20060088929A (en) * | 2005-02-02 | 2006-08-07 | 삼성전자주식회사 | Apparatus and method for processing hardware interrupt in linux-based system |
-
2007
- 2007-10-04 KR KR1020070100071A patent/KR100915803B1/en active IP Right Grant
- 2007-12-04 US US11/999,217 patent/US8677477B2/en not_active Expired - Fee Related
-
2008
- 2008-04-17 EP EP08154727.5A patent/EP2045747B1/en active Active
- 2008-04-30 CN CN200810096083.3A patent/CN101403973B/en active Active
-
2014
- 2014-03-18 US US14/218,706 patent/US20140201830A1/en not_active Abandoned
Patent Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5113442A (en) * | 1989-03-06 | 1992-05-12 | Lachman Associates, Inc. | Method and apparatus for providing access control in a secure operating system |
US6289462B1 (en) * | 1998-09-28 | 2001-09-11 | Argus Systems Group, Inc. | Trusted compartmentalized computer operating system |
US20060053426A1 (en) * | 2002-05-28 | 2006-03-09 | Symbian Limited | Secure mobile wireless device |
US7383437B1 (en) * | 2003-09-08 | 2008-06-03 | Sun Microsystems, Inc. | Method and system for implementing super-user-compatible privileges |
US20050091658A1 (en) * | 2003-10-24 | 2005-04-28 | Microsoft Corporation | Operating system resource protection |
US20050289545A1 (en) * | 2004-06-24 | 2005-12-29 | Blinick Stephen L | Method to enable user mode process to operate in a privileged execution mode |
US7669050B2 (en) * | 2004-06-24 | 2010-02-23 | International Business Machines Corporation | Method to enable user mode process to operate in a privileged execution mode |
US20060020063A1 (en) * | 2004-07-22 | 2006-01-26 | Guenther Gerhard K | Controlled finishes for free surface polyethylene resins |
US20070050369A1 (en) * | 2005-01-31 | 2007-03-01 | Stiegler Marc D | Accessing file under confinement |
US20060253909A1 (en) * | 2005-05-06 | 2006-11-09 | Mikhail Cherepov | Method to control and secure setuid/gid executables and processes |
US8677477B2 (en) * | 2006-12-05 | 2014-03-18 | Samsung Electronics Co., Ltd. | Application program launching method and system for improving security of embedded Linux kernel |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10205714B2 (en) | 2015-08-04 | 2019-02-12 | Electronics And Telecommunications Research Institute | Apparatus and method for process authentication in redundant system |
US10325116B2 (en) * | 2017-06-30 | 2019-06-18 | Vmware, Inc. | Dynamic privilege management in a computer system |
US11675902B2 (en) | 2018-12-05 | 2023-06-13 | Vmware, Inc. | Security detection system with privilege management |
CN111639020A (en) * | 2020-05-06 | 2020-09-08 | 贝壳技术有限公司 | Program bug reproduction method, system, device, electronic equipment and storage medium thereof |
Also Published As
Publication number | Publication date |
---|---|
EP2045747B1 (en) | 2020-03-04 |
KR20080052342A (en) | 2008-06-11 |
EP2045747A2 (en) | 2009-04-08 |
US20080134325A1 (en) | 2008-06-05 |
EP2045747A3 (en) | 2011-09-14 |
CN101403973B (en) | 2016-06-01 |
KR100915803B1 (en) | 2009-09-07 |
US8677477B2 (en) | 2014-03-18 |
CN101403973A (en) | 2009-04-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8677477B2 (en) | Application program launching method and system for improving security of embedded Linux kernel | |
US7389512B2 (en) | Interprocess communication within operating system partitions | |
US8250183B1 (en) | System and method for pre-installing of virtual server files | |
EP2513809B1 (en) | Systems and methods for service isolation | |
US7865952B1 (en) | Pre-emptive application blocking for updates | |
US8806494B2 (en) | Managed control of processes including privilege escalation | |
US8850549B2 (en) | Methods and systems for controlling access to resources and privileges per process | |
EP1963967B1 (en) | Methods for selecting between a predetermined number of execution methods for an application program | |
JP2010532047A (en) | Secure software deployment | |
US7882227B2 (en) | Mechanism for implementing file access control across a network using labeled containers | |
US7089297B1 (en) | Mechanism for automatically configuring a network resource | |
KR20050009198A (en) | Automatic detection and patching of vulnerable files | |
WO2005099342A2 (en) | A generic framework for runtime interception and execution control of interpreted languages | |
US8892878B2 (en) | Fine-grained privileges in operating system partitions | |
US7885975B2 (en) | Mechanism for implementing file access control using labeled containers | |
KR100988961B1 (en) | Side-by-side drivers | |
US20020103904A1 (en) | Method and apparatus for controlling access to files associated with a virtual server | |
US20070208873A1 (en) | Mechanism for enabling a network address to be shared by multiple labeled containers | |
US7188120B1 (en) | System statistics virtualization for operating systems partitions | |
US7950000B2 (en) | Architecture that restricts permissions granted to a build process | |
US8938473B2 (en) | Secure windowing for labeled containers | |
EP1480124A2 (en) | Method and system for associating resource pools with operating system partitions | |
KR100586486B1 (en) | Automatic patch management/distribution system and patch distribution method using the same | |
US11356438B2 (en) | Access management system with a secret isolation manager | |
O'Leary et al. | Defending the Windows Domain |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |